@payloadcms/drizzle 3.0.0-beta.117 → 3.0.0-beta.119

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/find/buildFindManyArgs.d.ts +2 -1
  2. package/dist/find/buildFindManyArgs.d.ts.map +1 -1
  3. package/dist/find/buildFindManyArgs.js +3 -2
  4. package/dist/find/buildFindManyArgs.js.map +1 -1
  5. package/dist/find/findMany.d.ts +2 -1
  6. package/dist/find/findMany.d.ts.map +1 -1
  7. package/dist/find/findMany.js +6 -5
  8. package/dist/find/findMany.js.map +1 -1
  9. package/dist/find/traverseFields.d.ts +2 -1
  10. package/dist/find/traverseFields.d.ts.map +1 -1
  11. package/dist/find/traverseFields.js +83 -74
  12. package/dist/find/traverseFields.js.map +1 -1
  13. package/dist/find.js +1 -1
  14. package/dist/find.js.map +1 -1
  15. package/dist/findGlobalVersions.js +1 -1
  16. package/dist/findGlobalVersions.js.map +1 -1
  17. package/dist/findVersions.js +1 -1
  18. package/dist/findVersions.js.map +1 -1
  19. package/dist/postgres/countDistinct.d.ts.map +1 -1
  20. package/dist/postgres/countDistinct.js +2 -3
  21. package/dist/postgres/countDistinct.js.map +1 -1
  22. package/dist/postgres/init.d.ts.map +1 -1
  23. package/dist/postgres/init.js +0 -1
  24. package/dist/postgres/init.js.map +1 -1
  25. package/dist/postgres/schema/build.d.ts +2 -3
  26. package/dist/postgres/schema/build.d.ts.map +1 -1
  27. package/dist/postgres/schema/build.js +1 -2
  28. package/dist/postgres/schema/build.js.map +1 -1
  29. package/dist/postgres/schema/traverseFields.d.ts +2 -3
  30. package/dist/postgres/schema/traverseFields.d.ts.map +1 -1
  31. package/dist/postgres/schema/traverseFields.js +1 -27
  32. package/dist/postgres/schema/traverseFields.js.map +1 -1
  33. package/dist/queries/addJoinTable.d.ts +11 -0
  34. package/dist/queries/addJoinTable.d.ts.map +1 -0
  35. package/dist/queries/addJoinTable.js +13 -0
  36. package/dist/queries/addJoinTable.js.map +1 -0
  37. package/dist/queries/buildOrderBy.d.ts +2 -2
  38. package/dist/queries/buildOrderBy.d.ts.map +1 -1
  39. package/dist/queries/buildOrderBy.js +32 -28
  40. package/dist/queries/buildOrderBy.js.map +1 -1
  41. package/dist/queries/buildQuery.d.ts +3 -3
  42. package/dist/queries/buildQuery.d.ts.map +1 -1
  43. package/dist/queries/buildQuery.js.map +1 -1
  44. package/dist/queries/getTableColumnFromPath.d.ts +1 -2
  45. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  46. package/dist/queries/getTableColumnFromPath.js +78 -81
  47. package/dist/queries/getTableColumnFromPath.js.map +1 -1
  48. package/dist/queryDrafts.d.ts.map +1 -1
  49. package/dist/queryDrafts.js +3 -1
  50. package/dist/queryDrafts.js.map +1 -1
  51. package/dist/utilities/getNameFromDrizzleTable.d.ts +3 -0
  52. package/dist/utilities/getNameFromDrizzleTable.d.ts.map +1 -0
  53. package/dist/utilities/getNameFromDrizzleTable.js +6 -0
  54. package/dist/utilities/getNameFromDrizzleTable.js.map +1 -0
  55. package/package.json +3 -3
@@ -4,12 +4,13 @@ import { fieldAffectsData, tabHasName } from 'payload/shared';
4
4
  import toSnakeCase from 'to-snake-case';
5
5
  import { validate as uuidValidate } from 'uuid';
6
6
  import { isPolymorphicRelationship } from '../utilities/isPolymorphicRelationship.js';
7
+ import { addJoinTable } from './addJoinTable.js';
7
8
  import { getTableAlias } from './getTableAlias.js';
8
9
  /**
9
10
  * Transforms path to table and column name or to a list of OR columns
10
11
  * Adds tables to `join`
11
12
  * @returns TableColumn
12
- */ export const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraintPath: incomingConstraintPath, constraints = [], fields, joins, locale: incomingLocale, pathSegments: incomingSegments, rootTableName: incomingRootTableName, selectFields, tableName, tableNameSuffix = '', useAlias, value })=>{
13
+ */ export const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraintPath: incomingConstraintPath, constraints = [], fields, joins, locale: incomingLocale, pathSegments: incomingSegments, rootTableName: incomingRootTableName, selectFields, tableName, tableNameSuffix = '', value })=>{
13
14
  const fieldPath = incomingSegments[0];
14
15
  let locale = incomingLocale;
15
16
  const rootTableName = incomingRootTableName || tableName;
@@ -62,7 +63,6 @@ import { getTableAlias } from './getTableAlias.js';
62
63
  selectFields,
63
64
  tableName: newTableName,
64
65
  tableNameSuffix,
65
- useAlias,
66
66
  value
67
67
  });
68
68
  }
@@ -84,7 +84,6 @@ import { getTableAlias } from './getTableAlias.js';
84
84
  selectFields,
85
85
  tableName: newTableName,
86
86
  tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,
87
- useAlias,
88
87
  value
89
88
  });
90
89
  }
@@ -103,7 +102,6 @@ import { getTableAlias } from './getTableAlias.js';
103
102
  selectFields,
104
103
  tableName: newTableName,
105
104
  tableNameSuffix,
106
- useAlias,
107
105
  value
108
106
  });
109
107
  }
@@ -111,17 +109,15 @@ import { getTableAlias } from './getTableAlias.js';
111
109
  {
112
110
  if (locale && field.localized && adapter.payload.config.localization) {
113
111
  newTableName = `${tableName}${adapter.localesSuffix}`;
114
- joins.push({
115
- condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),
116
- table: adapter.tables[newTableName]
117
- });
112
+ let condition = eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
118
113
  if (locale !== 'all') {
119
- constraints.push({
120
- columnName: '_locale',
121
- table: adapter.tables[newTableName],
122
- value: locale
123
- });
114
+ condition = and(condition, eq(adapter.tables[newTableName]._locale, locale));
124
115
  }
116
+ addJoinTable({
117
+ condition,
118
+ joins,
119
+ table: adapter.tables[newTableName]
120
+ });
125
121
  }
126
122
  return getTableColumnFromPath({
127
123
  adapter,
@@ -138,7 +134,6 @@ import { getTableAlias } from './getTableAlias.js';
138
134
  selectFields,
139
135
  tableName: newTableName,
140
136
  tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,
141
- useAlias,
142
137
  value
143
138
  });
144
139
  }
@@ -147,20 +142,22 @@ import { getTableAlias } from './getTableAlias.js';
147
142
  if (field.hasMany) {
148
143
  const newTableName = adapter.tableNameMap.get(`${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`);
149
144
  if (locale && field.localized && adapter.payload.config.localization) {
150
- joins.push({
151
- condition: and(eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent), eq(adapter.tables[newTableName]._locale, locale)),
152
- table: adapter.tables[newTableName]
153
- });
145
+ const conditions = [
146
+ eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),
147
+ eq(adapter.tables[newTableName]._locale, locale)
148
+ ];
154
149
  if (locale !== 'all') {
155
- constraints.push({
156
- columnName: '_locale',
157
- table: adapter.tables[newTableName],
158
- value: locale
159
- });
150
+ conditions.push(eq(adapter.tables[newTableName]._locale, locale));
160
151
  }
152
+ addJoinTable({
153
+ condition: and(...conditions),
154
+ joins,
155
+ table: adapter.tables[newTableName]
156
+ });
161
157
  } else {
162
- joins.push({
158
+ addJoinTable({
163
159
  condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),
160
+ joins,
164
161
  table: adapter.tables[newTableName]
165
162
  });
166
163
  }
@@ -189,20 +186,21 @@ import { getTableAlias } from './getTableAlias.js';
189
186
  like(adapter.tables[newTableName].path, `${constraintPath}${field.name}`)
190
187
  ];
191
188
  if (locale && field.localized && adapter.payload.config.localization) {
192
- joins.push({
193
- condition: and(...joinConstraints, eq(adapter.tables[newTableName]._locale, locale)),
194
- table: adapter.tables[newTableName]
195
- });
189
+ const conditions = [
190
+ ...joinConstraints
191
+ ];
196
192
  if (locale !== 'all') {
197
- constraints.push({
198
- columnName: 'locale',
199
- table: adapter.tables[newTableName],
200
- value: locale
201
- });
193
+ conditions.push(eq(adapter.tables[newTableName]._locale, locale));
202
194
  }
195
+ addJoinTable({
196
+ condition: and(...conditions),
197
+ joins,
198
+ table: adapter.tables[newTableName]
199
+ });
203
200
  } else {
204
- joins.push({
201
+ addJoinTable({
205
202
  condition: and(...joinConstraints),
203
+ joins,
206
204
  table: adapter.tables[newTableName]
207
205
  });
208
206
  }
@@ -221,20 +219,21 @@ import { getTableAlias } from './getTableAlias.js';
221
219
  const arrayParentTable = aliasTable || adapter.tables[tableName];
222
220
  constraintPath = `${constraintPath}${field.name}.%.`;
223
221
  if (locale && field.localized && adapter.payload.config.localization) {
224
- joins.push({
225
- condition: and(eq(arrayParentTable.id, adapter.tables[newTableName]._parentID), eq(adapter.tables[newTableName]._locale, locale)),
226
- table: adapter.tables[newTableName]
227
- });
222
+ const conditions = [
223
+ eq(arrayParentTable.id, adapter.tables[newTableName]._parentID)
224
+ ];
228
225
  if (locale !== 'all') {
229
- constraints.push({
230
- columnName: '_locale',
231
- table: adapter.tables[newTableName],
232
- value: locale
233
- });
226
+ conditions.push(eq(adapter.tables[newTableName]._locale, locale));
234
227
  }
228
+ addJoinTable({
229
+ condition: and(...conditions),
230
+ joins,
231
+ table: adapter.tables[newTableName]
232
+ });
235
233
  } else {
236
- joins.push({
234
+ addJoinTable({
237
235
  condition: eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),
236
+ joins,
238
237
  table: adapter.tables[newTableName]
239
238
  });
240
239
  }
@@ -250,7 +249,6 @@ import { getTableAlias } from './getTableAlias.js';
250
249
  rootTableName,
251
250
  selectFields,
252
251
  tableName: newTableName,
253
- useAlias,
254
252
  value
255
253
  });
256
254
  }
@@ -307,7 +305,6 @@ import { getTableAlias } from './getTableAlias.js';
307
305
  rootTableName,
308
306
  selectFields: blockSelectFields,
309
307
  tableName: newTableName,
310
- useAlias,
311
308
  value
312
309
  });
313
310
  } catch (error) {
@@ -323,17 +320,16 @@ import { getTableAlias } from './getTableAlias.js';
323
320
  ...blockSelectFields
324
321
  };
325
322
  if (field.localized && adapter.payload.config.localization) {
323
+ const conditions = [
324
+ eq((aliasTable || adapter.tables[tableName]).id, adapter.tables[newTableName]._parentID)
325
+ ];
326
+ if (locale !== 'all') {
327
+ conditions.push(eq(adapter.tables[newTableName]._locale, locale));
328
+ }
326
329
  joins.push({
327
- condition: and(eq((aliasTable || adapter.tables[tableName]).id, adapter.tables[newTableName]._parentID), eq(adapter.tables[newTableName]._locale, locale)),
330
+ condition: and(...conditions),
328
331
  table: adapter.tables[newTableName]
329
332
  });
330
- if (locale) {
331
- constraints.push({
332
- columnName: '_locale',
333
- table: adapter.tables[newTableName],
334
- value: locale
335
- });
336
- }
337
333
  } else {
338
334
  joins.push({
339
335
  condition: eq((aliasTable || adapter.tables[tableName]).id, adapter.tables[newTableName]._parentID),
@@ -367,17 +363,17 @@ import { getTableAlias } from './getTableAlias.js';
367
363
  });
368
364
  // Join in the relationships table
369
365
  if (locale && field.localized && adapter.payload.config.localization) {
366
+ const conditions = [
367
+ eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),
368
+ like(aliasRelationshipTable.path, `${constraintPath}${field.name}`)
369
+ ];
370
+ if (locale !== 'all') {
371
+ conditions.push(eq(aliasRelationshipTable.locale, locale));
372
+ }
370
373
  joins.push({
371
- condition: and(eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent), eq(aliasRelationshipTable.locale, locale), like(aliasRelationshipTable.path, `${constraintPath}${field.name}`)),
374
+ condition: and(...conditions),
372
375
  table: aliasRelationshipTable
373
376
  });
374
- if (locale !== 'all') {
375
- constraints.push({
376
- columnName: 'locale',
377
- table: aliasRelationshipTable,
378
- value: locale
379
- });
380
- }
381
377
  } else {
382
378
  // Join in the relationships table
383
379
  joins.push({
@@ -488,7 +484,6 @@ import { getTableAlias } from './getTableAlias.js';
488
484
  rootTableName: newTableName,
489
485
  selectFields,
490
486
  tableName: newTableName,
491
- useAlias,
492
487
  value
493
488
  });
494
489
  } else if (pathSegments.length > 1 && !(pathSegments.length === 2 && pathSegments[1] === 'id')) {
@@ -504,12 +499,20 @@ import { getTableAlias } from './getTableAlias.js';
504
499
  adapter,
505
500
  tableName: `${rootTableName}${adapter.localesSuffix}`
506
501
  });
507
- joins.push({
508
- condition: and(eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id), eq(aliasLocaleTable._locale, locale)),
509
- table: aliasLocaleTable
502
+ const condtions = [
503
+ eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id)
504
+ ];
505
+ if (locale !== 'all') {
506
+ condtions.push(eq(aliasLocaleTable._locale, locale));
507
+ }
508
+ const localesTable = adapter.tables[`${rootTableName}${adapter.localesSuffix}`];
509
+ addJoinTable({
510
+ condition: and(...condtions),
511
+ joins,
512
+ table: localesTable
510
513
  });
511
514
  joins.push({
512
- condition: eq(aliasLocaleTable[columnName], newAliasTable.id),
515
+ condition: eq(localesTable[columnName], newAliasTable.id),
513
516
  table: newAliasTable
514
517
  });
515
518
  } else {
@@ -530,7 +533,6 @@ import { getTableAlias } from './getTableAlias.js';
530
533
  pathSegments: pathSegments.slice(1),
531
534
  selectFields,
532
535
  tableName: newTableName,
533
- useAlias,
534
536
  value
535
537
  });
536
538
  }
@@ -548,22 +550,17 @@ import { getTableAlias } from './getTableAlias.js';
548
550
  // so it is not picked up below to be used as targetTable
549
551
  const parentTable = aliasTable || adapter.tables[tableName];
550
552
  newTableName = `${tableName}${adapter.localesSuffix}`;
551
- newTable = useAlias ? getTableAlias({
552
- adapter,
553
- tableName: newTableName
554
- }).newAliasTable : adapter.tables[newTableName];
555
- joins.push({
556
- condition: eq(parentTable.id, newTable._parentID),
553
+ newTable = adapter.tables[newTableName];
554
+ let condition = eq(parentTable.id, newTable._parentID);
555
+ if (locale !== 'all') {
556
+ condition = and(condition, eq(newTable._locale, locale));
557
+ }
558
+ addJoinTable({
559
+ condition,
560
+ joins,
557
561
  table: newTable
558
562
  });
559
563
  aliasTable = undefined;
560
- if (locale !== 'all') {
561
- constraints.push({
562
- columnName: '_locale',
563
- table: newTable,
564
- value: locale
565
- });
566
- }
567
564
  }
568
565
  const targetTable = aliasTable || newTable;
569
566
  selectFields[`${newTableName}.${columnPrefix}${field.name}`] = targetTable[`${columnPrefix}${field.name}`];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["import type { SQL } from 'drizzle-orm'\nimport type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core'\nimport type { Field, FieldAffectingData, NumberField, TabAsField, TextField } from 'payload'\n\nimport { and, eq, like, sql } from 'drizzle-orm'\nimport { type PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport { APIError, flattenTopLevelFields } from 'payload'\nimport { fieldAffectsData, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\nimport { validate as uuidValidate } from 'uuid'\n\nimport type { DrizzleAdapter, GenericColumn } from '../types.js'\nimport type { BuildQueryJoinAliases } from './buildQuery.js'\n\nimport { isPolymorphicRelationship } from '../utilities/isPolymorphicRelationship.js'\nimport { getTableAlias } from './getTableAlias.js'\n\ntype Constraint = {\n columnName: string\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n value: unknown\n}\n\ntype TableColumn = {\n columnName?: string\n columns?: {\n idType: 'number' | 'text' | 'uuid'\n rawColumn: SQL<unknown>\n }[]\n constraints: Constraint[]\n field: FieldAffectingData\n getNotNullColumnByValue?: (val: unknown) => string\n pathSegments?: string[]\n rawColumn?: SQL\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n}\n\ntype Args = {\n adapter: DrizzleAdapter\n aliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n collectionPath: string\n columnPrefix?: string\n constraintPath?: string\n constraints?: Constraint[]\n fields: (Field | TabAsField)[]\n joins: BuildQueryJoinAliases\n locale?: string\n pathSegments: string[]\n rootTableName?: string\n selectFields: Record<string, GenericColumn>\n tableName: string\n /**\n * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n */\n tableNameSuffix?: string\n useAlias?: boolean\n /**\n * The raw value of the query before sanitization\n */\n value: unknown\n}\n/**\n * Transforms path to table and column name or to a list of OR columns\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 joins,\n locale: incomingLocale,\n pathSegments: incomingSegments,\n rootTableName: incomingRootTableName,\n selectFields,\n tableName,\n tableNameSuffix = '',\n useAlias,\n value,\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: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n useAlias,\n value,\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: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n useAlias,\n value,\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n useAlias,\n value,\n })\n }\n\n case 'group': {\n if (locale && field.localized && adapter.payload.config.localization) {\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n table: adapter.tables[newTableName],\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: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n useAlias,\n value,\n })\n }\n\n case 'select': {\n if (field.hasMany) {\n const newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\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.push({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName: 'value',\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'text':\n case 'number': {\n if (field.hasMany) {\n let tableType = 'texts'\n let columnName = 'text'\n if (field.type === 'number') {\n tableType = 'numbers'\n columnName = 'number'\n }\n newTableName = `${rootTableName}_${tableType}`\n const joinConstraints = [\n eq(adapter.tables[rootTableName].id, adapter.tables[newTableName].parent),\n like(adapter.tables[newTableName].path, `${constraintPath}${field.name}`),\n ]\n\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(...joinConstraints, eq(adapter.tables[newTableName]._locale, locale)),\n table: adapter.tables[newTableName],\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.push({\n condition: and(...joinConstraints),\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName,\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'array': {\n newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const arrayParentTable = aliasTable || adapter.tables[tableName]\n\n constraintPath = `${constraintPath}${field.name}.%.`\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\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.push({\n condition: eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n useAlias,\n value,\n })\n }\n\n case 'blocks': {\n let blockTableColumn: TableColumn\n let newTableName: string\n\n // handle blockType queries\n if (pathSegments[1] === 'blockType') {\n // find the block config using the value\n const blockTypes = Array.isArray(value) ? value : [value]\n blockTypes.forEach((blockType) => {\n const block = field.blocks.find((block) => block.slug === blockType)\n newTableName = adapter.tableNameMap.get(\n `${tableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),\n table: newAliasTable,\n })\n constraints.push({\n columnName: '_path',\n table: newAliasTable,\n value: pathSegments[0],\n })\n })\n return {\n constraints,\n field,\n getNotNullColumnByValue: () => 'id',\n table: adapter.tables[tableName],\n }\n }\n\n const hasBlockField = field.blocks.some((block) => {\n newTableName = adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`)\n constraintPath = `${constraintPath}${field.name}.%.`\n\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields: blockSelectFields,\n tableName: newTableName,\n useAlias,\n value,\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.push({\n condition: and(\n eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\n })\n if (locale) {\n constraints.push({\n columnName: '_locale',\n table: adapter.tables[newTableName],\n value: locale,\n })\n }\n } else {\n joins.push({\n condition: eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n table: adapter.tables[newTableName],\n })\n }\n return true\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: blockTableColumn.table,\n }\n }\n break\n }\n\n case 'relationship':\n case 'upload': {\n const newCollectionPath = pathSegments.slice(1).join('.')\n if (Array.isArray(field.relationTo) || field.hasMany) {\n let relationshipFields\n const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n const {\n newAliasTable: aliasRelationshipTable,\n newAliasTableName: aliasRelationshipTableName,\n } = getTableAlias({ adapter, tableName: relationTableName })\n\n // Join in the relationships table\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n eq(aliasRelationshipTable.locale, locale),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n table: aliasRelationshipTable,\n })\n if (locale !== 'all') {\n constraints.push({\n columnName: 'locale',\n table: aliasRelationshipTable,\n value: locale,\n })\n }\n } else {\n // Join in the relationships table\n joins.push({\n condition: and(\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n table: aliasRelationshipTable,\n })\n }\n\n selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n let newAliasTable\n\n if (typeof field.relationTo === 'string') {\n const relationshipConfig = adapter.payload.collections[field.relationTo].config\n\n newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug))\n\n // parent to relationship join table\n relationshipFields = relationshipConfig.fields\n ;({ newAliasTable } = getTableAlias({ adapter, tableName: newTableName }))\n\n joins.push({\n condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n table: newAliasTable,\n })\n\n if (newCollectionPath === '' || newCollectionPath === 'id') {\n return {\n columnName: `${field.relationTo}ID`,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n }\n } else if (newCollectionPath === 'value') {\n const hasCustomCollectionWithCustomID = field.relationTo.some(\n (relationTo) => !!adapter.payload.collections[relationTo].customIDType,\n )\n\n const columns: TableColumn['columns'] = field.relationTo\n .map((relationTo) => {\n let idType: 'number' | 'text' | 'uuid' =\n adapter.idType === 'uuid' ? 'uuid' : 'number'\n\n const { customIDType } = adapter.payload.collections[relationTo]\n\n if (customIDType) {\n idType = customIDType\n }\n\n const idTypeTextOrUuid = idType === 'text' || idType === 'uuid'\n\n // Do not add the column to OR if we know that it can't match by the type\n // We can't do the same with idType: 'number' because `value` can be from the REST search query params\n if (typeof value === 'number' && idTypeTextOrUuid) {\n return null\n }\n\n if (\n Array.isArray(value) &&\n value.every((val) => typeof val === 'number') &&\n idTypeTextOrUuid\n ) {\n return null\n }\n\n // Do not add the UUID type column if incoming query value doesn't match UUID. If there aren't any collections with\n // a custom ID type, we skip this check\n // We need this because Postgres throws an error if querying by UUID column with a value that isn't a valid UUID.\n if (\n value &&\n !Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID\n ) {\n if (!uuidValidate(value)) {\n return null\n }\n }\n\n if (\n Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID &&\n !value.some((val) => uuidValidate(val))\n ) {\n return null\n }\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n idType,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n }\n })\n .filter(Boolean)\n\n return {\n columns,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n } else if (newCollectionPath === 'relationTo') {\n const relationTo = Array.isArray(field.relationTo)\n ? field.relationTo\n : [field.relationTo]\n\n return {\n constraints,\n field,\n getNotNullColumnByValue: (val) => {\n const matchedRelation = relationTo.find((relation) => relation === val)\n if (matchedRelation) {\n return `${matchedRelation}ID`\n }\n return undefined\n },\n table: aliasRelationshipTable,\n }\n } else if (isPolymorphicRelationship(value)) {\n const { relationTo } = value\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n constraints,\n field,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName: newTableName,\n selectFields,\n tableName: newTableName,\n useAlias,\n value,\n })\n } else if (\n pathSegments.length > 1 &&\n !(pathSegments.length === 2 && pathSegments[1] === 'id')\n ) {\n // simple relationships\n const columnName = `${columnPrefix}${field.name}`\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.relationTo].config.slug),\n )\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n if (field.localized && adapter.payload.config.localization) {\n const { newAliasTable: aliasLocaleTable } = getTableAlias({\n adapter,\n tableName: `${rootTableName}${adapter.localesSuffix}`,\n })\n\n joins.push({\n condition: and(\n eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id),\n eq(aliasLocaleTable._locale, locale),\n ),\n table: aliasLocaleTable,\n })\n joins.push({\n condition: eq(aliasLocaleTable[columnName], newAliasTable.id),\n table: newAliasTable,\n })\n } else {\n joins.push({\n condition: eq(\n newAliasTable.id,\n aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName],\n ),\n table: newAliasTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.relationTo].config.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n useAlias,\n value,\n })\n }\n break\n }\n\n default: {\n // fall through\n break\n }\n }\n\n if (fieldAffectsData(field)) {\n let newTable = adapter.tables[newTableName]\n\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 const parentTable = aliasTable || adapter.tables[tableName]\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n newTable = useAlias\n ? getTableAlias({ adapter, tableName: newTableName }).newAliasTable\n : adapter.tables[newTableName]\n\n joins.push({\n condition: eq(parentTable.id, newTable._parentID),\n table: newTable,\n })\n\n aliasTable = undefined\n\n if (locale !== 'all') {\n constraints.push({\n columnName: '_locale',\n table: newTable,\n value: locale,\n })\n }\n }\n\n const targetTable = aliasTable || newTable\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,\n table: targetTable,\n }\n }\n }\n\n throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["and","eq","like","sql","APIError","flattenTopLevelFields","fieldAffectsData","tabHasName","toSnakeCase","validate","uuidValidate","isPolymorphicRelationship","getTableAlias","getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","tableNameSuffix","useAlias","value","fieldPath","field","find","fieldToFind","name","newTableName","id","tables","columnName","type","idType","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","localesSuffix","push","condition","_parentID","hasMany","tableNameMap","get","parent","_locale","tableType","joinConstraints","path","arrayParentTable","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","slug","newAliasTable","getNotNullColumnByValue","hasBlockField","some","result","blockConstraints","blockSelectFields","error","concat","rawColumn","newCollectionPath","join","relationTo","relationshipFields","relationTableName","relationshipsSuffix","aliasRelationshipTable","newAliasTableName","aliasRelationshipTableName","relationshipConfig","collections","hasCustomCollectionWithCustomID","customIDType","columns","idTypeTextOrUuid","every","val","raw","filter","Boolean","matchedRelation","relation","undefined","length","aliasLocaleTable","newTable","parentTable","targetTable"],"mappings":"AAIA,SAASA,GAAG,EAAEC,EAAE,EAAEC,IAAI,EAAEC,GAAG,QAAQ,cAAa;AAEhD,SAASC,QAAQ,EAAEC,qBAAqB,QAAQ,UAAS;AACzD,SAASC,gBAAgB,EAAEC,UAAU,QAAQ,iBAAgB;AAC7D,OAAOC,iBAAiB,gBAAe;AACvC,SAASC,YAAYC,YAAY,QAAQ,OAAM;AAK/C,SAASC,yBAAyB,QAAQ,4CAA2C;AACrF,SAASC,aAAa,QAAQ,qBAAoB;AA8ClD;;;;CAIC,GACD,OAAO,MAAMC,yBAAyB,CAAC,EACrCC,OAAO,EACPC,UAAU,EACVC,cAAc,EACdC,eAAe,EAAE,EACjBC,gBAAgBC,sBAAsB,EACtCC,cAAc,EAAE,EAChBC,MAAM,EACNC,KAAK,EACLC,QAAQC,cAAc,EACtBC,cAAcC,gBAAgB,EAC9BC,eAAeC,qBAAqB,EACpCC,YAAY,EACZC,SAAS,EACTC,kBAAkB,EAAE,EACpBC,QAAQ,EACRC,KAAK,EACA;IACL,MAAMC,YAAYR,gBAAgB,CAAC,EAAE;IACrC,IAAIH,SAASC;IACb,MAAMG,gBAAgBC,yBAAyBE;IAC/C,IAAIZ,iBAAiBC,0BAA0B;IAE/C,MAAMgB,QAAQ9B,sBAAsBgB,QAAmBe,IAAI,CACzD,CAACC,cAAgB/B,iBAAiB+B,gBAAgBA,YAAYC,IAAI,KAAKJ;IAEzE,IAAIK,eAAeT;IAEnB,IAAI,CAACK,SAASD,cAAc,MAAM;QAChCL,aAAaW,EAAE,GAAG1B,QAAQ2B,MAAM,CAACF,aAAa,CAACC,EAAE;QACjD,OAAO;YACLE,YAAY;YACZtB;YACAe,OAAO;gBACLG,MAAM;gBACNK,MAAM7B,QAAQ8B,MAAM,KAAK,SAAS,SAAS;YAC7C;YACAC,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;QACrC;IACF;IAEA,IAAIJ,OAAO;QACT,MAAMV,eAAe;eAAIC;SAAiB;QAE1C,+BAA+B;QAC/B,qEAAqE;QACrE,IAAI,eAAeS,SAASA,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;YAClF,MAAMC,gBAAgBpC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,CAACE,WAAW,CAACf,IAAI,CACxE,CAACb,SAAWA,WAAWE,YAAY,CAAC,EAAE;YAGxC,IAAIyB,eAAe;gBACjB3B,SAAS2B;gBACTzB,aAAa2B,MAAM,CAAC,GAAG;YACzB;QACF;QAEA,OAAQjB,MAAMQ,IAAI;YAChB,KAAK;gBAAQ;oBACX,OAAO9B,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAE;wBACAC,QAAQc,MAAMkB,IAAI,CAACC,GAAG,CAAC,CAACC,MAAS,CAAA;gCAC/B,GAAGA,GAAG;gCACNZ,MAAM;4BACR,CAAA;wBACArB;wBACAC;wBACAE,cAAcA,aAAa+B,KAAK,CAAC;wBACjC7B;wBACAE;wBACAC,WAAWS;wBACXR;wBACAC;wBACAC;oBACF;gBACF;YACA,KAAK;gBAAO;oBACV,IAAI1B,WAAW4B,QAAQ;wBACrB,OAAOtB,uBAAuB;4BAC5BC;4BACAC;4BACAC;4BACAC,cAAc,CAAC,EAAEA,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC,CAAC;4BAC7CpB,gBAAgB,CAAC,EAAEA,eAAe,EAAEiB,MAAMG,IAAI,CAAC,CAAC,CAAC;4BACjDlB;4BACAC,QAAQc,MAAMd,MAAM;4BACpBC;4BACAC;4BACAE,cAAcA,aAAa+B,KAAK,CAAC;4BACjC7B;4BACAE;4BACAC,WAAWS;4BACXR,iBAAiB,CAAC,EAAEA,gBAAgB,EAAEvB,YAAY2B,MAAMG,IAAI,EAAE,CAAC,CAAC;4BAChEN;4BACAC;wBACF;oBACF;oBACA,OAAOpB,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAE;wBACAC,QAAQc,MAAMd,MAAM;wBACpBC;wBACAC;wBACAE,cAAcA,aAAa+B,KAAK,CAAC;wBACjC7B;wBACAE;wBACAC,WAAWS;wBACXR;wBACAC;wBACAC;oBACF;gBACF;YAEA,KAAK;gBAAS;oBACZ,IAAIV,UAAUY,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBACpEV,eAAe,CAAC,EAAET,UAAU,EAAEhB,QAAQ2C,aAAa,CAAC,CAAC;wBAErDnC,MAAMoC,IAAI,CAAC;4BACTC,WAAW1D,GAAGa,QAAQ2B,MAAM,CAACX,UAAU,CAACU,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACqB,SAAS;4BAClFf,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;wBACrC;wBACA,IAAIhB,WAAW,OAAO;4BACpBH,YAAYsC,IAAI,CAAC;gCACfhB,YAAY;gCACZG,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;gCACnCN,OAAOV;4BACT;wBACF;oBACF;oBACA,OAAOV,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC,cAAc,CAAC,EAAEA,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC,CAAC;wBAC7CpB,gBAAgB,CAAC,EAAEA,eAAe,EAAEiB,MAAMG,IAAI,CAAC,CAAC,CAAC;wBACjDlB;wBACAC,QAAQc,MAAMd,MAAM;wBACpBC;wBACAC;wBACAE,cAAcA,aAAa+B,KAAK,CAAC;wBACjC7B;wBACAE;wBACAC,WAAWS;wBACXR,iBAAiB,CAAC,EAAEA,gBAAgB,EAAEvB,YAAY2B,MAAMG,IAAI,EAAE,CAAC,CAAC;wBAChEN;wBACAC;oBACF;gBACF;YAEA,KAAK;gBAAU;oBACb,IAAIE,MAAM0B,OAAO,EAAE;wBACjB,MAAMtB,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CAC3C,CAAC,EAAEjC,UAAU,CAAC,EAAEC,gBAAgB,EAAEvB,YAAY2B,MAAMG,IAAI,EAAE,CAAC;wBAG7D,IAAIf,UAAUY,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BACpE3B,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,IACTC,GAAGa,QAAQ2B,MAAM,CAACX,UAAU,CAACU,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACyB,MAAM,GACpE/D,GAAGa,QAAQ2B,MAAM,CAACF,aAAa,CAAC0B,OAAO,EAAE1C;gCAE3CsB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;4BACA,IAAIhB,WAAW,OAAO;gCACpBH,YAAYsC,IAAI,CAAC;oCACfhB,YAAY;oCACZG,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;oCACnCN,OAAOV;gCACT;4BACF;wBACF,OAAO;4BACLD,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GAAGa,QAAQ2B,MAAM,CAACX,UAAU,CAACU,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACyB,MAAM;gCAC/EnB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;wBACF;wBAEA,OAAO;4BACLG,YAAY;4BACZtB;4BACAe;4BACAU,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;wBACrC;oBACF;oBACA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAU;oBACb,IAAIJ,MAAM0B,OAAO,EAAE;wBACjB,IAAIK,YAAY;wBAChB,IAAIxB,aAAa;wBACjB,IAAIP,MAAMQ,IAAI,KAAK,UAAU;4BAC3BuB,YAAY;4BACZxB,aAAa;wBACf;wBACAH,eAAe,CAAC,EAAEZ,cAAc,CAAC,EAAEuC,UAAU,CAAC;wBAC9C,MAAMC,kBAAkB;4BACtBlE,GAAGa,QAAQ2B,MAAM,CAACd,cAAc,CAACa,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACyB,MAAM;4BACxE9D,KAAKY,QAAQ2B,MAAM,CAACF,aAAa,CAAC6B,IAAI,EAAE,CAAC,EAAElD,eAAe,EAAEiB,MAAMG,IAAI,CAAC,CAAC;yBACzE;wBAED,IAAIf,UAAUY,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BACpE3B,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,OAAOmE,iBAAiBlE,GAAGa,QAAQ2B,MAAM,CAACF,aAAa,CAAC0B,OAAO,EAAE1C;gCAC5EsB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;4BACA,IAAIhB,WAAW,OAAO;gCACpBH,YAAYsC,IAAI,CAAC;oCACfhB,YAAY;oCACZG,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;oCACnCN,OAAOV;gCACT;4BACF;wBACF,OAAO;4BACLD,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,OAAOmE;gCAClBtB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;wBACF;wBAEA,OAAO;4BACLG;4BACAtB;4BACAe;4BACAU,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;wBACrC;oBACF;oBACA;gBACF;YAEA,KAAK;gBAAS;oBACZA,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CACrC,CAAC,EAAEjC,UAAU,CAAC,EAAEC,gBAAgB,EAAEvB,YAAY2B,MAAMG,IAAI,EAAE,CAAC;oBAG7D,MAAM+B,mBAAmBtD,cAAcD,QAAQ2B,MAAM,CAACX,UAAU;oBAEhEZ,iBAAiB,CAAC,EAAEA,eAAe,EAAEiB,MAAMG,IAAI,CAAC,GAAG,CAAC;oBACpD,IAAIf,UAAUY,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBACpE3B,MAAMoC,IAAI,CAAC;4BACTC,WAAW3D,IACTC,GAAGoE,iBAAiB7B,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACqB,SAAS,GAC9D3D,GAAGa,QAAQ2B,MAAM,CAACF,aAAa,CAAC0B,OAAO,EAAE1C;4BAE3CsB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;wBACrC;wBACA,IAAIhB,WAAW,OAAO;4BACpBH,YAAYsC,IAAI,CAAC;gCACfhB,YAAY;gCACZG,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;gCACnCN,OAAOV;4BACT;wBACF;oBACF,OAAO;wBACLD,MAAMoC,IAAI,CAAC;4BACTC,WAAW1D,GAAGoE,iBAAiB7B,EAAE,EAAE1B,QAAQ2B,MAAM,CAACF,aAAa,CAACqB,SAAS;4BACzEf,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;wBACrC;oBACF;oBACA,OAAO1B,uBAAuB;wBAC5BC;wBACAE;wBACAE;wBACAE;wBACAC,QAAQc,MAAMd,MAAM;wBACpBC;wBACAC;wBACAE,cAAcA,aAAa+B,KAAK,CAAC;wBACjC7B;wBACAE;wBACAC,WAAWS;wBACXP;wBACAC;oBACF;gBACF;YAEA,KAAK;gBAAU;oBACb,IAAIqC;oBACJ,IAAI/B;oBAEJ,2BAA2B;oBAC3B,IAAId,YAAY,CAAC,EAAE,KAAK,aAAa;wBACnC,wCAAwC;wBACxC,MAAM8C,aAAaC,MAAMC,OAAO,CAACxC,SAASA,QAAQ;4BAACA;yBAAM;wBACzDsC,WAAWG,OAAO,CAAC,CAACC;4BAClB,MAAMC,QAAQzC,MAAM0C,MAAM,CAACzC,IAAI,CAAC,CAACwC,QAAUA,MAAME,IAAI,KAAKH;4BAC1DpC,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CACrC,CAAC,EAAEjC,UAAU,QAAQ,EAAEtB,YAAYoE,MAAME,IAAI,EAAE,CAAC;4BAGlD,MAAM,EAAEC,aAAa,EAAE,GAAGnE,cAAc;gCAAEE;gCAASgB,WAAWS;4BAAa;4BAE3EjB,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GAAGa,QAAQ2B,MAAM,CAACX,UAAU,CAACU,EAAE,EAAEuC,cAAcnB,SAAS;gCACnEf,OAAOkC;4BACT;4BACA3D,YAAYsC,IAAI,CAAC;gCACfhB,YAAY;gCACZG,OAAOkC;gCACP9C,OAAOR,YAAY,CAAC,EAAE;4BACxB;wBACF;wBACA,OAAO;4BACLL;4BACAe;4BACA6C,yBAAyB,IAAM;4BAC/BnC,OAAO/B,QAAQ2B,MAAM,CAACX,UAAU;wBAClC;oBACF;oBAEA,MAAMmD,gBAAgB9C,MAAM0C,MAAM,CAACK,IAAI,CAAC,CAACN;wBACvCrC,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CAAC,CAAC,EAAEjC,UAAU,QAAQ,EAAEtB,YAAYoE,MAAME,IAAI,EAAE,CAAC;wBACxF5D,iBAAiB,CAAC,EAAEA,eAAe,EAAEiB,MAAMG,IAAI,CAAC,GAAG,CAAC;wBAEpD,IAAI6C;wBACJ,MAAMC,mBAAmB,EAAE;wBAC3B,MAAMC,oBAAoB,CAAC;wBAC3B,IAAI;4BACFF,SAAStE,uBAAuB;gCAC9BC;gCACAE;gCACAE;gCACAE,aAAagE;gCACb/D,QAAQuD,MAAMvD,MAAM;gCACpBC;gCACAC;gCACAE,cAAcA,aAAa+B,KAAK,CAAC;gCACjC7B;gCACAE,cAAcwD;gCACdvD,WAAWS;gCACXP;gCACAC;4BACF;wBACF,EAAE,OAAOqD,OAAO;wBACd,oDAAoD;wBACtD;wBACA,IAAI,CAACH,QAAQ;4BACX;wBACF;wBACAb,mBAAmBa;wBACnB/D,cAAcA,YAAYmE,MAAM,CAACH;wBACjCvD,eAAe;4BAAE,GAAGA,YAAY;4BAAE,GAAGwD,iBAAiB;wBAAC;wBACvD,IAAIlD,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BAC1D3B,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,IACTC,GACE,AAACc,CAAAA,cAAcD,QAAQ2B,MAAM,CAACX,UAAU,AAAD,EAAGU,EAAE,EAC5C1B,QAAQ2B,MAAM,CAACF,aAAa,CAACqB,SAAS,GAExC3D,GAAGa,QAAQ2B,MAAM,CAACF,aAAa,CAAC0B,OAAO,EAAE1C;gCAE3CsB,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;4BACA,IAAIhB,QAAQ;gCACVH,YAAYsC,IAAI,CAAC;oCACfhB,YAAY;oCACZG,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;oCACnCN,OAAOV;gCACT;4BACF;wBACF,OAAO;4BACLD,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GACT,AAACc,CAAAA,cAAcD,QAAQ2B,MAAM,CAACX,UAAU,AAAD,EAAGU,EAAE,EAC5C1B,QAAQ2B,MAAM,CAACF,aAAa,CAACqB,SAAS;gCAExCf,OAAO/B,QAAQ2B,MAAM,CAACF,aAAa;4BACrC;wBACF;wBACA,OAAO;oBACT;oBACA,IAAI0C,eAAe;wBACjB,OAAO;4BACLvC,YAAY4B,iBAAiB5B,UAAU;4BACvCtB;4BACAe,OAAOmC,iBAAiBnC,KAAK;4BAC7BV,cAAcA,aAAa+B,KAAK,CAAC;4BACjCgC,WAAWlB,iBAAiBkB,SAAS;4BACrC3C,OAAOyB,iBAAiBzB,KAAK;wBAC/B;oBACF;oBACA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAU;oBACb,MAAM4C,oBAAoBhE,aAAa+B,KAAK,CAAC,GAAGkC,IAAI,CAAC;oBACrD,IAAIlB,MAAMC,OAAO,CAACtC,MAAMwD,UAAU,KAAKxD,MAAM0B,OAAO,EAAE;wBACpD,IAAI+B;wBACJ,MAAMC,oBAAoB,CAAC,EAAElE,cAAc,EAAEb,QAAQgF,mBAAmB,CAAC,CAAC;wBAC1E,MAAM,EACJf,eAAegB,sBAAsB,EACrCC,mBAAmBC,0BAA0B,EAC9C,GAAGrF,cAAc;4BAAEE;4BAASgB,WAAW+D;wBAAkB;wBAE1D,kCAAkC;wBAClC,IAAItE,UAAUY,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BACpE3B,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,IACTC,GAAG,AAACc,CAAAA,cAAcD,QAAQ2B,MAAM,CAACd,cAAc,AAAD,EAAGa,EAAE,EAAEuD,uBAAuB/B,MAAM,GAClF/D,GAAG8F,uBAAuBxE,MAAM,EAAEA,SAClCrB,KAAK6F,uBAAuB3B,IAAI,EAAE,CAAC,EAAElD,eAAe,EAAEiB,MAAMG,IAAI,CAAC,CAAC;gCAEpEO,OAAOkD;4BACT;4BACA,IAAIxE,WAAW,OAAO;gCACpBH,YAAYsC,IAAI,CAAC;oCACfhB,YAAY;oCACZG,OAAOkD;oCACP9D,OAAOV;gCACT;4BACF;wBACF,OAAO;4BACL,kCAAkC;4BAClCD,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,IACTC,GAAG,AAACc,CAAAA,cAAcD,QAAQ2B,MAAM,CAACd,cAAc,AAAD,EAAGa,EAAE,EAAEuD,uBAAuB/B,MAAM,GAClF9D,KAAK6F,uBAAuB3B,IAAI,EAAE,CAAC,EAAElD,eAAe,EAAEiB,MAAMG,IAAI,CAAC,CAAC;gCAEpEO,OAAOkD;4BACT;wBACF;wBAEAlE,YAAY,CAAC,CAAC,EAAEgE,kBAAkB,KAAK,CAAC,CAAC,GAAGE,uBAAuB3B,IAAI;wBAEvE,IAAIW;wBAEJ,IAAI,OAAO5C,MAAMwD,UAAU,KAAK,UAAU;4BACxC,MAAMO,qBAAqBpF,QAAQiC,OAAO,CAACoD,WAAW,CAAChE,MAAMwD,UAAU,CAAC,CAAC3C,MAAM;4BAE/ET,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CAACvD,YAAY0F,mBAAmBpB,IAAI;4BAE3E,oCAAoC;4BACpCc,qBAAqBM,mBAAmB7E,MAAM;4BAC5C,CAAA,EAAE0D,aAAa,EAAE,GAAGnE,cAAc;gCAAEE;gCAASgB,WAAWS;4BAAa,EAAC;4BAExEjB,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GAAG8E,cAAcvC,EAAE,EAAEuD,sBAAsB,CAAC,CAAC,EAAE5D,MAAMwD,UAAU,CAAC,EAAE,CAAC,CAAC;gCAC/E9C,OAAOkC;4BACT;4BAEA,IAAIU,sBAAsB,MAAMA,sBAAsB,MAAM;gCAC1D,OAAO;oCACL/C,YAAY,CAAC,EAAEP,MAAMwD,UAAU,CAAC,EAAE,CAAC;oCACnCvE;oCACAe;oCACAU,OAAOkD;gCACT;4BACF;wBACF,OAAO,IAAIN,sBAAsB,SAAS;4BACxC,MAAMW,kCAAkCjE,MAAMwD,UAAU,CAACT,IAAI,CAC3D,CAACS,aAAe,CAAC,CAAC7E,QAAQiC,OAAO,CAACoD,WAAW,CAACR,WAAW,CAACU,YAAY;4BAGxE,MAAMC,UAAkCnE,MAAMwD,UAAU,CACrDrC,GAAG,CAAC,CAACqC;gCACJ,IAAI/C,SACF9B,QAAQ8B,MAAM,KAAK,SAAS,SAAS;gCAEvC,MAAM,EAAEyD,YAAY,EAAE,GAAGvF,QAAQiC,OAAO,CAACoD,WAAW,CAACR,WAAW;gCAEhE,IAAIU,cAAc;oCAChBzD,SAASyD;gCACX;gCAEA,MAAME,mBAAmB3D,WAAW,UAAUA,WAAW;gCAEzD,yEAAyE;gCACzE,sGAAsG;gCACtG,IAAI,OAAOX,UAAU,YAAYsE,kBAAkB;oCACjD,OAAO;gCACT;gCAEA,IACE/B,MAAMC,OAAO,CAACxC,UACdA,MAAMuE,KAAK,CAAC,CAACC,MAAQ,OAAOA,QAAQ,aACpCF,kBACA;oCACA,OAAO;gCACT;gCAEA,mHAAmH;gCACnH,uCAAuC;gCACvC,iHAAiH;gCACjH,IACEtE,SACA,CAACuC,MAAMC,OAAO,CAACxC,UACfW,WAAW,UACXwD,iCACA;oCACA,IAAI,CAAC1F,aAAauB,QAAQ;wCACxB,OAAO;oCACT;gCACF;gCAEA,IACEuC,MAAMC,OAAO,CAACxC,UACdW,WAAW,UACXwD,mCACA,CAACnE,MAAMiD,IAAI,CAAC,CAACuB,MAAQ/F,aAAa+F,OAClC;oCACA,OAAO;gCACT;gCAEA,MAAMZ,oBAAoB/E,QAAQgD,YAAY,CAACC,GAAG,CAChDvD,YAAYM,QAAQiC,OAAO,CAACoD,WAAW,CAACR,WAAW,CAAC3C,MAAM,CAAC8B,IAAI;gCAGjE,OAAO;oCACLlC;oCACA4C,WAAWrF,IAAIuG,GAAG,CAAC,CAAC,CAAC,EAAET,2BAA2B,GAAG,EAAEJ,kBAAkB,IAAI,CAAC;gCAChF;4BACF,GACCc,MAAM,CAACC;4BAEV,OAAO;gCACLN;gCACAlF;gCACAe;gCACAU,OAAOkD;4BACT;wBACF,OAAO,IAAIN,sBAAsB,cAAc;4BAC7C,MAAME,aAAanB,MAAMC,OAAO,CAACtC,MAAMwD,UAAU,IAC7CxD,MAAMwD,UAAU,GAChB;gCAACxD,MAAMwD,UAAU;6BAAC;4BAEtB,OAAO;gCACLvE;gCACAe;gCACA6C,yBAAyB,CAACyB;oCACxB,MAAMI,kBAAkBlB,WAAWvD,IAAI,CAAC,CAAC0E,WAAaA,aAAaL;oCACnE,IAAII,iBAAiB;wCACnB,OAAO,CAAC,EAAEA,gBAAgB,EAAE,CAAC;oCAC/B;oCACA,OAAOE;gCACT;gCACAlE,OAAOkD;4BACT;wBACF,OAAO,IAAIpF,0BAA0BsB,QAAQ;4BAC3C,MAAM,EAAE0D,UAAU,EAAE,GAAG1D;4BAEvB,MAAM4D,oBAAoB/E,QAAQgD,YAAY,CAACC,GAAG,CAChDvD,YAAYM,QAAQiC,OAAO,CAACoD,WAAW,CAACR,WAAW,CAAC3C,MAAM,CAAC8B,IAAI;4BAGjE,OAAO;gCACL1D;gCACAe;gCACAqD,WAAWrF,IAAIuG,GAAG,CAAC,CAAC,CAAC,EAAET,2BAA2B,GAAG,EAAEJ,kBAAkB,IAAI,CAAC;gCAC9EhD,OAAOkD;4BACT;wBACF,OAAO;4BACL,MAAM,IAAI3F,SAAS;wBACrB;wBAEA,OAAOS,uBAAuB;4BAC5BC;4BACAC,YAAYgE;4BACZ/D,gBAAgByE;4BAChBrE;4BACAC,QAAQuE;4BACRtE;4BACAC;4BACAE,cAAcA,aAAa+B,KAAK,CAAC;4BACjC7B,eAAeY;4BACfV;4BACAC,WAAWS;4BACXP;4BACAC;wBACF;oBACF,OAAO,IACLR,aAAauF,MAAM,GAAG,KACtB,CAAEvF,CAAAA,aAAauF,MAAM,KAAK,KAAKvF,YAAY,CAAC,EAAE,KAAK,IAAG,GACtD;wBACA,uBAAuB;wBACvB,MAAMiB,aAAa,CAAC,EAAEzB,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC;wBACjD,MAAMC,eAAezB,QAAQgD,YAAY,CAACC,GAAG,CAC3CvD,YAAYM,QAAQiC,OAAO,CAACoD,WAAW,CAAChE,MAAMwD,UAAU,CAAC,CAAC3C,MAAM,CAAC8B,IAAI;wBAEvE,MAAM,EAAEC,aAAa,EAAE,GAAGnE,cAAc;4BAAEE;4BAASgB,WAAWS;wBAAa;wBAE3E,IAAIJ,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BAC1D,MAAM,EAAE8B,eAAekC,gBAAgB,EAAE,GAAGrG,cAAc;gCACxDE;gCACAgB,WAAW,CAAC,EAAEH,cAAc,EAAEb,QAAQ2C,aAAa,CAAC,CAAC;4BACvD;4BAEAnC,MAAMoC,IAAI,CAAC;gCACTC,WAAW3D,IACTC,GAAGgH,iBAAiBrD,SAAS,EAAE9C,QAAQ2B,MAAM,CAACd,cAAc,CAACa,EAAE,GAC/DvC,GAAGgH,iBAAiBhD,OAAO,EAAE1C;gCAE/BsB,OAAOoE;4BACT;4BACA3F,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GAAGgH,gBAAgB,CAACvE,WAAW,EAAEqC,cAAcvC,EAAE;gCAC5DK,OAAOkC;4BACT;wBACF,OAAO;4BACLzD,MAAMoC,IAAI,CAAC;gCACTC,WAAW1D,GACT8E,cAAcvC,EAAE,EAChBzB,aAAaA,UAAU,CAAC2B,WAAW,GAAG5B,QAAQ2B,MAAM,CAACX,UAAU,CAACY,WAAW;gCAE7EG,OAAOkC;4BACT;wBACF;wBAEA,OAAOlE,uBAAuB;4BAC5BC;4BACAC,YAAYgE;4BACZ/D,gBAAgByE;4BAChBvE,gBAAgB;4BAChBE;4BACAC,QAAQP,QAAQiC,OAAO,CAACoD,WAAW,CAAChE,MAAMwD,UAAU,CAAC,CAAC3C,MAAM,CAAC3B,MAAM;4BACnEC;4BACAC;4BACAE,cAAcA,aAAa+B,KAAK,CAAC;4BACjC3B;4BACAC,WAAWS;4BACXP;4BACAC;wBACF;oBACF;oBACA;gBACF;YAEA;gBAAS;oBAEP;gBACF;QACF;QAEA,IAAI3B,iBAAiB6B,QAAQ;YAC3B,IAAI+E,WAAWpG,QAAQ2B,MAAM,CAACF,aAAa;YAE3C,IAAIJ,MAAMW,SAAS,IAAIhC,QAAQiC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;gBAC1D,yEAAyE;gBACzE,yDAAyD;gBACzD,MAAMkE,cAAcpG,cAAcD,QAAQ2B,MAAM,CAACX,UAAU;gBAC3DS,eAAe,CAAC,EAAET,UAAU,EAAEhB,QAAQ2C,aAAa,CAAC,CAAC;gBAErDyD,WAAWlF,WACPpB,cAAc;oBAAEE;oBAASgB,WAAWS;gBAAa,GAAGwC,aAAa,GACjEjE,QAAQ2B,MAAM,CAACF,aAAa;gBAEhCjB,MAAMoC,IAAI,CAAC;oBACTC,WAAW1D,GAAGkH,YAAY3E,EAAE,EAAE0E,SAAStD,SAAS;oBAChDf,OAAOqE;gBACT;gBAEAnG,aAAagG;gBAEb,IAAIxF,WAAW,OAAO;oBACpBH,YAAYsC,IAAI,CAAC;wBACfhB,YAAY;wBACZG,OAAOqE;wBACPjF,OAAOV;oBACT;gBACF;YACF;YAEA,MAAM6F,cAAcrG,cAAcmG;YAElCrF,YAAY,CAAC,CAAC,EAAEU,aAAa,CAAC,EAAEtB,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC,CAAC,GAC1D8E,WAAW,CAAC,CAAC,EAAEnG,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC,CAAC;YAE7C,OAAO;gBACLI,YAAY,CAAC,EAAEzB,aAAa,EAAEkB,MAAMG,IAAI,CAAC,CAAC;gBAC1ClB;gBACAe;gBACAV;gBACAoB,OAAOuE;YACT;QACF;IACF;IAEA,MAAM,IAAIhH,SAAS,CAAC,8BAA8B,EAAE8B,UAAU,CAAC;AACjE,EAAC"}
1
+ {"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["import type { SQL } from 'drizzle-orm'\nimport type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core'\nimport type { Field, FieldAffectingData, NumberField, TabAsField, TextField } from 'payload'\n\nimport { and, eq, like, sql } from 'drizzle-orm'\nimport { type PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport { APIError, flattenTopLevelFields } from 'payload'\nimport { fieldAffectsData, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\nimport { validate as uuidValidate } from 'uuid'\n\nimport type { DrizzleAdapter, GenericColumn } from '../types.js'\nimport type { BuildQueryJoinAliases } from './buildQuery.js'\n\nimport { isPolymorphicRelationship } from '../utilities/isPolymorphicRelationship.js'\nimport { addJoinTable } from './addJoinTable.js'\nimport { getTableAlias } from './getTableAlias.js'\n\ntype Constraint = {\n columnName: string\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n value: unknown\n}\n\ntype TableColumn = {\n columnName?: string\n columns?: {\n idType: 'number' | 'text' | 'uuid'\n rawColumn: SQL<unknown>\n }[]\n constraints: Constraint[]\n field: FieldAffectingData\n getNotNullColumnByValue?: (val: unknown) => string\n pathSegments?: string[]\n rawColumn?: SQL\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n}\n\ntype Args = {\n adapter: DrizzleAdapter\n aliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n collectionPath: string\n columnPrefix?: string\n constraintPath?: string\n constraints?: Constraint[]\n fields: (Field | TabAsField)[]\n joins: BuildQueryJoinAliases\n locale?: string\n pathSegments: string[]\n rootTableName?: string\n selectFields: Record<string, GenericColumn>\n tableName: string\n /**\n * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n */\n tableNameSuffix?: string\n /**\n * The raw value of the query before sanitization\n */\n value: unknown\n}\n/**\n * Transforms path to table and column name or to a list of OR columns\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 joins,\n locale: incomingLocale,\n pathSegments: incomingSegments,\n rootTableName: incomingRootTableName,\n selectFields,\n tableName,\n tableNameSuffix = '',\n value,\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: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n value,\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: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n value,\n })\n }\n\n case 'group': {\n if (locale && field.localized && adapter.payload.config.localization) {\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n let condition = eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition,\n joins,\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n\n case 'select': {\n if (field.hasMany) {\n const newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n if (locale && field.localized && adapter.payload.config.localization) {\n const conditions = [\n eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName]._locale, locale),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n addJoinTable({\n condition: and(...conditions),\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName: 'value',\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'text':\n case 'number': {\n if (field.hasMany) {\n let tableType = 'texts'\n let columnName = 'text'\n if (field.type === 'number') {\n tableType = 'numbers'\n columnName = 'number'\n }\n newTableName = `${rootTableName}_${tableType}`\n const joinConstraints = [\n eq(adapter.tables[rootTableName].id, adapter.tables[newTableName].parent),\n like(adapter.tables[newTableName].path, `${constraintPath}${field.name}`),\n ]\n\n if (locale && field.localized && adapter.payload.config.localization) {\n const conditions = [...joinConstraints]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n addJoinTable({\n condition: and(...conditions),\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: and(...joinConstraints),\n joins,\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName,\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'array': {\n newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n const arrayParentTable = aliasTable || adapter.tables[tableName]\n\n constraintPath = `${constraintPath}${field.name}.%.`\n if (locale && field.localized && adapter.payload.config.localization) {\n const conditions = [eq(arrayParentTable.id, adapter.tables[newTableName]._parentID)]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n addJoinTable({\n condition: and(...conditions),\n joins,\n table: adapter.tables[newTableName],\n })\n } else {\n addJoinTable({\n condition: eq(arrayParentTable.id, adapter.tables[newTableName]._parentID),\n joins,\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n\n case 'blocks': {\n let blockTableColumn: TableColumn\n let newTableName: string\n\n // handle blockType queries\n if (pathSegments[1] === 'blockType') {\n // find the block config using the value\n const blockTypes = Array.isArray(value) ? value : [value]\n blockTypes.forEach((blockType) => {\n const block = field.blocks.find((block) => block.slug === blockType)\n newTableName = adapter.tableNameMap.get(\n `${tableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),\n table: newAliasTable,\n })\n constraints.push({\n columnName: '_path',\n table: newAliasTable,\n value: pathSegments[0],\n })\n })\n return {\n constraints,\n field,\n getNotNullColumnByValue: () => 'id',\n table: adapter.tables[tableName],\n }\n }\n\n const hasBlockField = field.blocks.some((block) => {\n newTableName = adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`)\n constraintPath = `${constraintPath}${field.name}.%.`\n\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields: blockSelectFields,\n tableName: newTableName,\n value,\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 const conditions = [\n eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(adapter.tables[newTableName]._locale, locale))\n }\n\n joins.push({\n condition: and(...conditions),\n table: adapter.tables[newTableName],\n })\n } else {\n joins.push({\n condition: eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n table: adapter.tables[newTableName],\n })\n }\n return true\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: blockTableColumn.table,\n }\n }\n break\n }\n\n case 'relationship':\n case 'upload': {\n const newCollectionPath = pathSegments.slice(1).join('.')\n if (Array.isArray(field.relationTo) || field.hasMany) {\n let relationshipFields\n const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n const {\n newAliasTable: aliasRelationshipTable,\n newAliasTableName: aliasRelationshipTableName,\n } = getTableAlias({ adapter, tableName: relationTableName })\n\n // Join in the relationships table\n if (locale && field.localized && adapter.payload.config.localization) {\n const conditions = [\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ]\n\n if (locale !== 'all') {\n conditions.push(eq(aliasRelationshipTable.locale, locale))\n }\n joins.push({\n condition: and(...conditions),\n table: aliasRelationshipTable,\n })\n } else {\n // Join in the relationships table\n joins.push({\n condition: and(\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n table: aliasRelationshipTable,\n })\n }\n\n selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n let newAliasTable\n\n if (typeof field.relationTo === 'string') {\n const relationshipConfig = adapter.payload.collections[field.relationTo].config\n\n newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug))\n\n // parent to relationship join table\n relationshipFields = relationshipConfig.fields\n ;({ newAliasTable } = getTableAlias({ adapter, tableName: newTableName }))\n\n joins.push({\n condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n table: newAliasTable,\n })\n\n if (newCollectionPath === '' || newCollectionPath === 'id') {\n return {\n columnName: `${field.relationTo}ID`,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n }\n } else if (newCollectionPath === 'value') {\n const hasCustomCollectionWithCustomID = field.relationTo.some(\n (relationTo) => !!adapter.payload.collections[relationTo].customIDType,\n )\n\n const columns: TableColumn['columns'] = field.relationTo\n .map((relationTo) => {\n let idType: 'number' | 'text' | 'uuid' =\n adapter.idType === 'uuid' ? 'uuid' : 'number'\n\n const { customIDType } = adapter.payload.collections[relationTo]\n\n if (customIDType) {\n idType = customIDType\n }\n\n const idTypeTextOrUuid = idType === 'text' || idType === 'uuid'\n\n // Do not add the column to OR if we know that it can't match by the type\n // We can't do the same with idType: 'number' because `value` can be from the REST search query params\n if (typeof value === 'number' && idTypeTextOrUuid) {\n return null\n }\n\n if (\n Array.isArray(value) &&\n value.every((val) => typeof val === 'number') &&\n idTypeTextOrUuid\n ) {\n return null\n }\n\n // Do not add the UUID type column if incoming query value doesn't match UUID. If there aren't any collections with\n // a custom ID type, we skip this check\n // We need this because Postgres throws an error if querying by UUID column with a value that isn't a valid UUID.\n if (\n value &&\n !Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID\n ) {\n if (!uuidValidate(value)) {\n return null\n }\n }\n\n if (\n Array.isArray(value) &&\n idType === 'uuid' &&\n hasCustomCollectionWithCustomID &&\n !value.some((val) => uuidValidate(val))\n ) {\n return null\n }\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n idType,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\n }\n })\n .filter(Boolean)\n\n return {\n columns,\n constraints,\n field,\n table: aliasRelationshipTable,\n }\n } else if (newCollectionPath === 'relationTo') {\n const relationTo = Array.isArray(field.relationTo)\n ? field.relationTo\n : [field.relationTo]\n\n return {\n constraints,\n field,\n getNotNullColumnByValue: (val) => {\n const matchedRelation = relationTo.find((relation) => relation === val)\n if (matchedRelation) {\n return `${matchedRelation}ID`\n }\n return undefined\n },\n table: aliasRelationshipTable,\n }\n } else if (isPolymorphicRelationship(value)) {\n const { relationTo } = value\n\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return {\n constraints,\n field,\n rawColumn: sql.raw(`\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`),\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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName: newTableName,\n selectFields,\n tableName: newTableName,\n value,\n })\n } else if (\n pathSegments.length > 1 &&\n !(pathSegments.length === 2 && pathSegments[1] === 'id')\n ) {\n // simple relationships\n const columnName = `${columnPrefix}${field.name}`\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.relationTo].config.slug),\n )\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n if (field.localized && adapter.payload.config.localization) {\n const { newAliasTable: aliasLocaleTable } = getTableAlias({\n adapter,\n tableName: `${rootTableName}${adapter.localesSuffix}`,\n })\n\n const condtions = [eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id)]\n\n if (locale !== 'all') {\n condtions.push(eq(aliasLocaleTable._locale, locale))\n }\n\n const localesTable = adapter.tables[`${rootTableName}${adapter.localesSuffix}`]\n\n addJoinTable({\n condition: and(...condtions),\n joins,\n table: localesTable,\n })\n\n joins.push({\n condition: eq(localesTable[columnName], newAliasTable.id),\n table: newAliasTable,\n })\n } else {\n joins.push({\n condition: eq(\n newAliasTable.id,\n aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName],\n ),\n table: newAliasTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.relationTo].config.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n break\n }\n\n default: {\n // fall through\n break\n }\n }\n\n if (fieldAffectsData(field)) {\n let newTable = adapter.tables[newTableName]\n\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 const parentTable = aliasTable || adapter.tables[tableName]\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n newTable = adapter.tables[newTableName]\n\n let condition = eq(parentTable.id, newTable._parentID)\n\n if (locale !== 'all') {\n condition = and(condition, eq(newTable._locale, locale))\n }\n\n addJoinTable({\n condition,\n joins,\n table: newTable,\n })\n\n aliasTable = undefined\n }\n\n const targetTable = aliasTable || newTable\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,\n table: targetTable,\n }\n }\n }\n\n throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["and","eq","like","sql","APIError","flattenTopLevelFields","fieldAffectsData","tabHasName","toSnakeCase","validate","uuidValidate","isPolymorphicRelationship","addJoinTable","getTableAlias","getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","tableNameSuffix","value","fieldPath","field","find","fieldToFind","name","newTableName","id","tables","columnName","type","idType","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","localesSuffix","condition","_parentID","_locale","hasMany","tableNameMap","get","conditions","parent","push","tableType","joinConstraints","path","arrayParentTable","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","slug","newAliasTable","getNotNullColumnByValue","hasBlockField","some","result","blockConstraints","blockSelectFields","error","concat","rawColumn","newCollectionPath","join","relationTo","relationshipFields","relationTableName","relationshipsSuffix","aliasRelationshipTable","newAliasTableName","aliasRelationshipTableName","relationshipConfig","collections","hasCustomCollectionWithCustomID","customIDType","columns","idTypeTextOrUuid","every","val","raw","filter","Boolean","matchedRelation","relation","undefined","length","aliasLocaleTable","condtions","localesTable","newTable","parentTable","targetTable"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAkB,WAAW,EAA6B,MAAM,SAAS,CAAA;AASrF,eAAO,MAAM,WAAW,EAAE,WAoCzB,CAAA"}
1
+ {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAA6B,WAAW,EAA6B,MAAM,SAAS,CAAA;AAShG,eAAO,MAAM,WAAW,EAAE,WAgDzB,CAAA"}
@@ -1,7 +1,7 @@
1
1
  import { buildVersionCollectionFields, combineQueries } from 'payload';
2
2
  import toSnakeCase from 'to-snake-case';
3
3
  import { findMany } from './find/findMany.js';
4
- export const queryDrafts = async function queryDrafts({ collection, limit, locale, page = 1, pagination, req = {}, sort, where }) {
4
+ export const queryDrafts = async function queryDrafts({ collection, joins, limit, locale, page = 1, pagination, req = {}, sort, where }) {
5
5
  const collectionConfig = this.payload.collections[collection].config;
6
6
  const tableName = this.tableNameMap.get(`_${toSnakeCase(collectionConfig.slug)}${this.versionsSuffix}`);
7
7
  const fields = buildVersionCollectionFields(this.payload.config, collectionConfig);
@@ -13,6 +13,7 @@ export const queryDrafts = async function queryDrafts({ collection, limit, local
13
13
  const result = await findMany({
14
14
  adapter: this,
15
15
  fields,
16
+ joins,
16
17
  limit,
17
18
  locale,
18
19
  page,
@@ -20,6 +21,7 @@ export const queryDrafts = async function queryDrafts({ collection, limit, local
20
21
  req,
21
22
  sort,
22
23
  tableName,
24
+ versions: true,
23
25
  where: combinedWhere
24
26
  });
25
27
  return {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/queryDrafts.ts"],"sourcesContent":["import type { PayloadRequest, QueryDrafts, SanitizedCollectionConfig } from 'payload'\n\nimport { buildVersionCollectionFields, combineQueries } from 'payload'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const queryDrafts: QueryDrafts = async function queryDrafts(\n this: DrizzleAdapter,\n { collection, limit, locale, page = 1, pagination, req = {} as PayloadRequest, sort, where },\n) {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n const tableName = this.tableNameMap.get(\n `_${toSnakeCase(collectionConfig.slug)}${this.versionsSuffix}`,\n )\n const fields = buildVersionCollectionFields(this.payload.config, collectionConfig)\n\n const combinedWhere = combineQueries({ latest: { equals: true } }, where)\n\n const result = await findMany({\n adapter: this,\n fields,\n limit,\n locale,\n page,\n pagination,\n req,\n sort,\n tableName,\n where: combinedWhere,\n })\n\n return {\n ...result,\n docs: result.docs.map((doc) => {\n doc = {\n id: doc.parent,\n ...doc.version,\n }\n\n return doc\n }),\n }\n}\n"],"names":["buildVersionCollectionFields","combineQueries","toSnakeCase","findMany","queryDrafts","collection","limit","locale","page","pagination","req","sort","where","collectionConfig","payload","collections","config","tableName","tableNameMap","get","slug","versionsSuffix","fields","combinedWhere","latest","equals","result","adapter","docs","map","doc","id","parent","version"],"mappings":"AAEA,SAASA,4BAA4B,EAAEC,cAAc,QAAQ,UAAS;AACtE,OAAOC,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,cAA2B,eAAeA,YAErD,EAAEC,UAAU,EAAEC,KAAK,EAAEC,MAAM,EAAEC,OAAO,CAAC,EAAEC,UAAU,EAAEC,MAAM,CAAC,CAAmB,EAAEC,IAAI,EAAEC,KAAK,EAAE;IAE5F,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACV,WAAW,CAACW,MAAM;IAC/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CACrC,CAAC,CAAC,EAAEjB,YAAYW,iBAAiBO,IAAI,EAAE,EAAE,IAAI,CAACC,cAAc,CAAC,CAAC;IAEhE,MAAMC,SAAStB,6BAA6B,IAAI,CAACc,OAAO,CAACE,MAAM,EAAEH;IAEjE,MAAMU,gBAAgBtB,eAAe;QAAEuB,QAAQ;YAAEC,QAAQ;QAAK;IAAE,GAAGb;IAEnE,MAAMc,SAAS,MAAMvB,SAAS;QAC5BwB,SAAS,IAAI;QACbL;QACAhB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAM;QACAL,OAAOW;IACT;IAEA,OAAO;QACL,GAAGG,MAAM;QACTE,MAAMF,OAAOE,IAAI,CAACC,GAAG,CAAC,CAACC;YACrBA,MAAM;gBACJC,IAAID,IAAIE,MAAM;gBACd,GAAGF,IAAIG,OAAO;YAChB;YAEA,OAAOH;QACT;IACF;AACF,EAAC"}
1
+ {"version":3,"sources":["../src/queryDrafts.ts"],"sourcesContent":["import type { JoinQuery, PayloadRequest, QueryDrafts, SanitizedCollectionConfig } from 'payload'\n\nimport { buildVersionCollectionFields, combineQueries } from 'payload'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const queryDrafts: QueryDrafts = async function queryDrafts(\n this: DrizzleAdapter,\n {\n collection,\n joins,\n limit,\n locale,\n page = 1,\n pagination,\n req = {} as PayloadRequest,\n sort,\n where,\n },\n) {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n const tableName = this.tableNameMap.get(\n `_${toSnakeCase(collectionConfig.slug)}${this.versionsSuffix}`,\n )\n const fields = buildVersionCollectionFields(this.payload.config, collectionConfig)\n\n const combinedWhere = combineQueries({ latest: { equals: true } }, where)\n\n const result = await findMany({\n adapter: this,\n fields,\n joins,\n limit,\n locale,\n page,\n pagination,\n req,\n sort,\n tableName,\n versions: true,\n where: combinedWhere,\n })\n\n return {\n ...result,\n docs: result.docs.map((doc) => {\n doc = {\n id: doc.parent,\n ...doc.version,\n }\n\n return doc\n }),\n }\n}\n"],"names":["buildVersionCollectionFields","combineQueries","toSnakeCase","findMany","queryDrafts","collection","joins","limit","locale","page","pagination","req","sort","where","collectionConfig","payload","collections","config","tableName","tableNameMap","get","slug","versionsSuffix","fields","combinedWhere","latest","equals","result","adapter","versions","docs","map","doc","id","parent","version"],"mappings":"AAEA,SAASA,4BAA4B,EAAEC,cAAc,QAAQ,UAAS;AACtE,OAAOC,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,cAA2B,eAAeA,YAErD,EACEC,UAAU,EACVC,KAAK,EACLC,KAAK,EACLC,MAAM,EACNC,OAAO,CAAC,EACRC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,IAAI,EACJC,KAAK,EACN;IAED,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACX,WAAW,CAACY,MAAM;IAC/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CACrC,CAAC,CAAC,EAAElB,YAAYY,iBAAiBO,IAAI,EAAE,EAAE,IAAI,CAACC,cAAc,CAAC,CAAC;IAEhE,MAAMC,SAASvB,6BAA6B,IAAI,CAACe,OAAO,CAACE,MAAM,EAAEH;IAEjE,MAAMU,gBAAgBvB,eAAe;QAAEwB,QAAQ;YAAEC,QAAQ;QAAK;IAAE,GAAGb;IAEnE,MAAMc,SAAS,MAAMxB,SAAS;QAC5ByB,SAAS,IAAI;QACbL;QACAjB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAM;QACAW,UAAU;QACVhB,OAAOW;IACT;IAEA,OAAO;QACL,GAAGG,MAAM;QACTG,MAAMH,OAAOG,IAAI,CAACC,GAAG,CAAC,CAACC;YACrBA,MAAM;gBACJC,IAAID,IAAIE,MAAM;gBACd,GAAGF,IAAIG,OAAO;YAChB;YAEA,OAAOH;QACT;IACF;AACF,EAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Table } from 'drizzle-orm';
2
+ export declare const getNameFromDrizzleTable: (table: Table) => string;
3
+ //# sourceMappingURL=getNameFromDrizzleTable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getNameFromDrizzleTable.d.ts","sourceRoot":"","sources":["../../src/utilities/getNameFromDrizzleTable.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AAExC,eAAO,MAAM,uBAAuB,UAAW,KAAK,KAAG,MAMtD,CAAA"}
@@ -0,0 +1,6 @@
1
+ export const getNameFromDrizzleTable = (table)=>{
2
+ const symbol = Object.getOwnPropertySymbols(table).find((symb)=>symb.description.includes('Name'));
3
+ return table[symbol];
4
+ };
5
+
6
+ //# sourceMappingURL=getNameFromDrizzleTable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utilities/getNameFromDrizzleTable.ts"],"sourcesContent":["import type { Table } from 'drizzle-orm'\n\nexport const getNameFromDrizzleTable = (table: Table): string => {\n const symbol = Object.getOwnPropertySymbols(table).find((symb) =>\n symb.description.includes('Name'),\n )\n\n return table[symbol]\n}\n"],"names":["getNameFromDrizzleTable","table","symbol","Object","getOwnPropertySymbols","find","symb","description","includes"],"mappings":"AAEA,OAAO,MAAMA,0BAA0B,CAACC;IACtC,MAAMC,SAASC,OAAOC,qBAAqB,CAACH,OAAOI,IAAI,CAAC,CAACC,OACvDA,KAAKC,WAAW,CAACC,QAAQ,CAAC;IAG5B,OAAOP,KAAK,CAACC,OAAO;AACtB,EAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/drizzle",
3
- "version": "3.0.0-beta.117",
3
+ "version": "3.0.0-beta.119",
4
4
  "description": "A library of shared functions used by different payload database adapters",
5
5
  "homepage": "https://payloadcms.com",
6
6
  "repository": {
@@ -46,10 +46,10 @@
46
46
  "@types/pg": "8.10.2",
47
47
  "@types/to-snake-case": "1.0.0",
48
48
  "@payloadcms/eslint-config": "3.0.0-beta.112",
49
- "payload": "3.0.0-beta.117"
49
+ "payload": "3.0.0-beta.119"
50
50
  },
51
51
  "peerDependencies": {
52
- "payload": "3.0.0-beta.117"
52
+ "payload": "3.0.0-beta.119"
53
53
  },
54
54
  "scripts": {
55
55
  "build": "pnpm build:swc && pnpm build:types",