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

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 (74) hide show
  1. package/dist/create.d.ts.map +1 -1
  2. package/dist/create.js +2 -1
  3. package/dist/create.js.map +1 -1
  4. package/dist/createGlobalVersion.d.ts +1 -1
  5. package/dist/createGlobalVersion.d.ts.map +1 -1
  6. package/dist/createGlobalVersion.js +2 -1
  7. package/dist/createGlobalVersion.js.map +1 -1
  8. package/dist/createVersion.d.ts +1 -1
  9. package/dist/createVersion.d.ts.map +1 -1
  10. package/dist/createVersion.js +2 -1
  11. package/dist/createVersion.js.map +1 -1
  12. package/dist/deleteOne.d.ts.map +1 -1
  13. package/dist/deleteOne.js +2 -1
  14. package/dist/deleteOne.js.map +1 -1
  15. package/dist/find/buildFindManyArgs.d.ts +3 -2
  16. package/dist/find/buildFindManyArgs.d.ts.map +1 -1
  17. package/dist/find/buildFindManyArgs.js +38 -22
  18. package/dist/find/buildFindManyArgs.js.map +1 -1
  19. package/dist/find/findMany.d.ts +1 -1
  20. package/dist/find/findMany.d.ts.map +1 -1
  21. package/dist/find/findMany.js +2 -1
  22. package/dist/find/findMany.js.map +1 -1
  23. package/dist/find/traverseFields.d.ts +11 -2
  24. package/dist/find/traverseFields.d.ts.map +1 -1
  25. package/dist/find/traverseFields.js +165 -40
  26. package/dist/find/traverseFields.js.map +1 -1
  27. package/dist/find.d.ts.map +1 -1
  28. package/dist/find.js +2 -1
  29. package/dist/find.js.map +1 -1
  30. package/dist/findGlobal.d.ts.map +1 -1
  31. package/dist/findGlobal.js +2 -1
  32. package/dist/findGlobal.js.map +1 -1
  33. package/dist/findGlobalVersions.d.ts.map +1 -1
  34. package/dist/findGlobalVersions.js +2 -1
  35. package/dist/findGlobalVersions.js.map +1 -1
  36. package/dist/findOne.d.ts +1 -1
  37. package/dist/findOne.d.ts.map +1 -1
  38. package/dist/findOne.js +2 -1
  39. package/dist/findOne.js.map +1 -1
  40. package/dist/findVersions.d.ts.map +1 -1
  41. package/dist/findVersions.js +2 -1
  42. package/dist/findVersions.js.map +1 -1
  43. package/dist/postgres/createDatabase.d.ts.map +1 -1
  44. package/dist/postgres/createDatabase.js +2 -2
  45. package/dist/postgres/createDatabase.js.map +1 -1
  46. package/dist/queryDrafts.d.ts.map +1 -1
  47. package/dist/queryDrafts.js +2 -1
  48. package/dist/queryDrafts.js.map +1 -1
  49. package/dist/transform/read/traverseFields.d.ts.map +1 -1
  50. package/dist/transform/read/traverseFields.js +1 -1
  51. package/dist/transform/read/traverseFields.js.map +1 -1
  52. package/dist/update.d.ts.map +1 -1
  53. package/dist/update.js +2 -1
  54. package/dist/update.js.map +1 -1
  55. package/dist/updateGlobal.d.ts +1 -1
  56. package/dist/updateGlobal.d.ts.map +1 -1
  57. package/dist/updateGlobal.js +2 -1
  58. package/dist/updateGlobal.js.map +1 -1
  59. package/dist/updateGlobalVersion.d.ts +1 -1
  60. package/dist/updateGlobalVersion.d.ts.map +1 -1
  61. package/dist/updateGlobalVersion.js +2 -1
  62. package/dist/updateGlobalVersion.js.map +1 -1
  63. package/dist/updateVersion.d.ts +1 -1
  64. package/dist/updateVersion.d.ts.map +1 -1
  65. package/dist/updateVersion.js +2 -1
  66. package/dist/updateVersion.js.map +1 -1
  67. package/dist/upsertRow/index.d.ts +1 -1
  68. package/dist/upsertRow/index.d.ts.map +1 -1
  69. package/dist/upsertRow/index.js +2 -1
  70. package/dist/upsertRow/index.js.map +1 -1
  71. package/dist/upsertRow/types.d.ts +3 -1
  72. package/dist/upsertRow/types.d.ts.map +1 -1
  73. package/dist/upsertRow/types.js.map +1 -1
  74. package/package.json +4 -4
@@ -3,7 +3,7 @@ import { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared';
3
3
  import toSnakeCase from 'to-snake-case';
4
4
  import buildQuery from '../queries/buildQuery.js';
5
5
  import { chainMethods } from './chainMethods.js';
6
- export const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, depth, fields, joinQuery = {}, joins, locale, path, tablePath, topLevelArgs, topLevelTableName, versions })=>{
6
+ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, depth, fields, joinQuery = {}, joins, locale, path, select, selectAllOnCurrentLevel = false, selectMode, tablePath, topLevelArgs, topLevelTableName, versions, withinLocalizedField = false, withTabledFields })=>{
7
7
  fields.forEach((field)=>{
8
8
  if (fieldIsVirtual(field)) {
9
9
  return;
@@ -27,9 +27,12 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
27
27
  joinQuery,
28
28
  joins,
29
29
  path,
30
+ select,
31
+ selectMode,
30
32
  tablePath,
31
33
  topLevelArgs,
32
- topLevelTableName
34
+ topLevelTableName,
35
+ withTabledFields
33
36
  });
34
37
  return;
35
38
  }
@@ -37,6 +40,14 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
37
40
  field.tabs.forEach((tab)=>{
38
41
  const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path;
39
42
  const tabTablePath = tabHasName(tab) ? `${tablePath}${toSnakeCase(tab.name)}_` : tablePath;
43
+ const tabSelect = tabHasName(tab) ? select?.[tab.name] : select;
44
+ if (tabSelect === false) {
45
+ return;
46
+ }
47
+ let tabSelectAllOnCurrentLevel = selectAllOnCurrentLevel;
48
+ if (tabHasName(tab) && select && !tabSelectAllOnCurrentLevel) {
49
+ tabSelectAllOnCurrentLevel = select[tab.name] === true || selectMode === 'exclude' && typeof select[tab.name] === 'undefined';
50
+ }
40
51
  traverseFields({
41
52
  _locales,
42
53
  adapter,
@@ -47,10 +58,14 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
47
58
  joinQuery,
48
59
  joins,
49
60
  path: tabPath,
61
+ select: typeof tabSelect === 'object' ? tabSelect : undefined,
62
+ selectAllOnCurrentLevel: tabSelectAllOnCurrentLevel,
63
+ selectMode,
50
64
  tablePath: tabTablePath,
51
65
  topLevelArgs,
52
66
  topLevelTableName,
53
- versions
67
+ versions,
68
+ withTabledFields
54
69
  });
55
70
  });
56
71
  return;
@@ -59,8 +74,17 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
59
74
  switch(field.type){
60
75
  case 'array':
61
76
  {
77
+ const arraySelect = selectAllOnCurrentLevel ? true : select?.[field.name];
78
+ if (select) {
79
+ if (selectMode === 'include' && typeof arraySelect === 'undefined' || selectMode === 'exclude' && arraySelect === false) {
80
+ break;
81
+ }
82
+ }
62
83
  const withArray = {
63
- columns: {
84
+ columns: typeof arraySelect === 'object' ? {
85
+ id: true,
86
+ _order: true
87
+ } : {
64
88
  _parentID: false
65
89
  },
66
90
  orderBy: ({ _order }, { asc })=>[
@@ -69,10 +93,20 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
69
93
  with: {}
70
94
  };
71
95
  const arrayTableName = adapter.tableNameMap.get(`${currentTableName}_${tablePath}${toSnakeCase(field.name)}`);
96
+ if (typeof arraySelect === 'object') {
97
+ if (adapter.tables[arrayTableName]._locale) {
98
+ withArray.columns._locale = true;
99
+ }
100
+ if (adapter.tables[arrayTableName]._uuid) {
101
+ withArray.columns._uuid = true;
102
+ }
103
+ }
72
104
  const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`;
73
105
  if (adapter.tables[arrayTableNameWithLocales]) {
74
106
  withArray.with._locales = {
75
- columns: {
107
+ columns: typeof arraySelect === 'object' ? {
108
+ _locale: true
109
+ } : {
76
110
  id: false,
77
111
  _parentID: false
78
112
  },
@@ -89,15 +123,27 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
89
123
  fields: field.fields,
90
124
  joinQuery,
91
125
  path: '',
126
+ select: typeof arraySelect === 'object' ? arraySelect : undefined,
127
+ selectMode,
92
128
  tablePath: '',
93
129
  topLevelArgs,
94
- topLevelTableName
130
+ topLevelTableName,
131
+ withinLocalizedField: withinLocalizedField || field.localized,
132
+ withTabledFields
95
133
  });
134
+ if (typeof arraySelect === 'object' && withArray.with._locales && Object.keys(withArray.with._locales).length === 1) {
135
+ delete withArray.with._locales;
136
+ }
96
137
  break;
97
138
  }
98
139
  case 'select':
99
140
  {
100
141
  if (field.hasMany) {
142
+ if (select) {
143
+ if (selectMode === 'include' && !select[field.name] || selectMode === 'exclude' && select[field.name] === false) {
144
+ break;
145
+ }
146
+ }
101
147
  const withSelect = {
102
148
  columns: {
103
149
  id: false,
@@ -113,43 +159,94 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
113
159
  break;
114
160
  }
115
161
  case 'blocks':
116
- field.blocks.forEach((block)=>{
117
- const blockKey = `_blocks_${block.slug}`;
118
- if (!topLevelArgs[blockKey]) {
119
- const withBlock = {
120
- columns: {
121
- _parentID: false
122
- },
123
- orderBy: ({ _order }, { asc })=>[
124
- asc(_order)
125
- ],
126
- with: {}
127
- };
128
- const tableName = adapter.tableNameMap.get(`${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`);
129
- if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {
130
- withBlock.with._locales = {
162
+ {
163
+ const blocksSelect = selectAllOnCurrentLevel ? true : select?.[field.name];
164
+ if (select) {
165
+ if (selectMode === 'include' && !blocksSelect || selectMode === 'exclude' && blocksSelect === false) {
166
+ break;
167
+ }
168
+ }
169
+ field.blocks.forEach((block)=>{
170
+ const blockKey = `_blocks_${block.slug}`;
171
+ let blockSelect;
172
+ let blockSelectMode = selectMode;
173
+ if (selectMode === 'include' && blocksSelect === true) {
174
+ blockSelect = true;
175
+ }
176
+ if (typeof blocksSelect === 'object') {
177
+ if (typeof blocksSelect[block.slug] === 'object') {
178
+ blockSelect = blocksSelect[block.slug];
179
+ } else if (selectMode === 'include' && typeof blocksSelect[block.slug] === 'undefined' || selectMode === 'exclude' && blocksSelect[block.slug] === false) {
180
+ blockSelect = {};
181
+ blockSelectMode = 'include';
182
+ } else if (selectMode === 'include' && blocksSelect[block.slug] === true) {
183
+ blockSelect = true;
184
+ }
185
+ }
186
+ if (!topLevelArgs[blockKey]) {
187
+ const withBlock = {
188
+ columns: typeof blockSelect === 'object' ? {
189
+ id: true,
190
+ _order: true,
191
+ _path: true
192
+ } : {
193
+ _parentID: false
194
+ },
195
+ orderBy: ({ _order }, { asc })=>[
196
+ asc(_order)
197
+ ],
131
198
  with: {}
132
199
  };
200
+ const tableName = adapter.tableNameMap.get(`${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`);
201
+ if (typeof blockSelect === 'object') {
202
+ if (adapter.tables[tableName]._locale) {
203
+ withBlock.columns._locale = true;
204
+ }
205
+ if (adapter.tables[tableName]._uuid) {
206
+ withBlock.columns._uuid = true;
207
+ }
208
+ }
209
+ if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {
210
+ withBlock.with._locales = {
211
+ with: {}
212
+ };
213
+ if (typeof blockSelect === 'object') {
214
+ withBlock.with._locales.columns = {
215
+ _locale: true
216
+ };
217
+ }
218
+ }
219
+ topLevelArgs.with[blockKey] = withBlock;
220
+ traverseFields({
221
+ _locales: withBlock.with._locales,
222
+ adapter,
223
+ currentArgs: withBlock,
224
+ currentTableName: tableName,
225
+ depth,
226
+ fields: block.fields,
227
+ joinQuery,
228
+ path: '',
229
+ select: typeof blockSelect === 'object' ? blockSelect : undefined,
230
+ selectMode: blockSelectMode,
231
+ tablePath: '',
232
+ topLevelArgs,
233
+ topLevelTableName,
234
+ withinLocalizedField: withinLocalizedField || field.localized,
235
+ withTabledFields
236
+ });
237
+ if (typeof blockSelect === 'object' && withBlock.with._locales && Object.keys(withBlock.with._locales.columns).length === 1) {
238
+ delete withBlock.with._locales;
239
+ }
133
240
  }
134
- topLevelArgs.with[blockKey] = withBlock;
135
- traverseFields({
136
- _locales: withBlock.with._locales,
137
- adapter,
138
- currentArgs: withBlock,
139
- currentTableName: tableName,
140
- depth,
141
- fields: block.fields,
142
- joinQuery,
143
- path: '',
144
- tablePath: '',
145
- topLevelArgs,
146
- topLevelTableName
147
- });
148
- }
149
- });
150
- break;
241
+ });
242
+ break;
243
+ }
151
244
  case 'group':
152
245
  {
246
+ const groupSelect = select?.[field.name];
247
+ if (groupSelect === false) {
248
+ break;
249
+ }
153
250
  traverseFields({
154
251
  _locales,
155
252
  adapter,
@@ -160,10 +257,15 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
160
257
  joinQuery,
161
258
  joins,
162
259
  path: `${path}${field.name}_`,
260
+ select: typeof groupSelect === 'object' ? groupSelect : undefined,
261
+ selectAllOnCurrentLevel: selectAllOnCurrentLevel || groupSelect === true || selectMode === 'exclude' && typeof groupSelect === 'undefined',
262
+ selectMode,
163
263
  tablePath: `${tablePath}${toSnakeCase(field.name)}_`,
164
264
  topLevelArgs,
165
265
  topLevelTableName,
166
- versions
266
+ versions,
267
+ withinLocalizedField: withinLocalizedField || field.localized,
268
+ withTabledFields
167
269
  });
168
270
  break;
169
271
  }
@@ -173,7 +275,10 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
173
275
  if (joinQuery === false) {
174
276
  break;
175
277
  }
176
- const { limit: limitArg = 10, sort, where } = joinQuery[`${path.replaceAll('_', '.')}${field.name}`] || {};
278
+ if (select && selectMode === 'include' && !select[field.name] || selectMode === 'exclude' && select[field.name] === false) {
279
+ break;
280
+ }
281
+ const { limit: limitArg = field.defaultLimit ?? 10, sort = field.defaultSort, where } = joinQuery[`${path.replaceAll('_', '.')}${field.name}`] || {};
177
282
  let limit = limitArg;
178
283
  if (limit !== 0) {
179
284
  // get an additional document and slice it later to determine if there is a next page
@@ -285,6 +390,26 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
285
390
  }
286
391
  default:
287
392
  {
393
+ if (!select && !selectAllOnCurrentLevel) {
394
+ break;
395
+ }
396
+ if (selectAllOnCurrentLevel || selectMode === 'include' && select[field.name] === true || selectMode === 'exclude' && typeof select[field.name] === 'undefined') {
397
+ const fieldPath = `${path}${field.name}`;
398
+ if ((field.localized || withinLocalizedField) && _locales) {
399
+ _locales.columns[fieldPath] = true;
400
+ } else if (adapter.tables[currentTableName]?.[fieldPath]) {
401
+ currentArgs.columns[fieldPath] = true;
402
+ }
403
+ if (!withTabledFields.rels && field.type === 'relationship' && (field.hasMany || Array.isArray(field.relationTo))) {
404
+ withTabledFields.rels = true;
405
+ }
406
+ if (!withTabledFields.numbers && field.type === 'number' && field.hasMany) {
407
+ withTabledFields.numbers = true;
408
+ }
409
+ if (!withTabledFields.texts && field.type === 'text' && field.hasMany) {
410
+ withTabledFields.texts = true;
411
+ }
412
+ }
288
413
  break;
289
414
  }
290
415
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { Field, JoinQuery } from 'payload'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, ChainedMethods, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport buildQuery from '../queries/buildQuery.js'\nimport { chainMethods } from './chainMethods.js'\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n currentArgs: Result\n currentTableName: string\n depth?: number\n fields: Field[]\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n path: string\n tablePath: string\n topLevelArgs: Record<string, unknown>\n topLevelTableName: string\n versions?: boolean\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields,\n joinQuery = {},\n joins,\n locale,\n path,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n // handle simple relationship\n if (\n depth > 0 &&\n (field.type === 'upload' || field.type === 'relationship') &&\n !field.hasMany &&\n typeof field.relationTo === 'string'\n ) {\n if (field.localized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\n if (field.type === 'collapsible' || field.type === 'row') {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n })\n\n return\n }\n\n if (field.type === 'tabs') {\n field.tabs.forEach((tab) => {\n const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path\n const tabTablePath = tabHasName(tab) ? `${tablePath}${toSnakeCase(tab.name)}_` : tablePath\n\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: tab.fields,\n joinQuery,\n joins,\n path: tabPath,\n tablePath: tabTablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n })\n })\n\n return\n }\n\n if (fieldAffectsData(field)) {\n switch (field.type) {\n case 'array': {\n const withArray: Result = {\n columns: {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const arrayTableName = adapter.tableNameMap.get(\n `${currentTableName}_${tablePath}${toSnakeCase(field.name)}`,\n )\n\n const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`\n\n if (adapter.tables[arrayTableNameWithLocales]) {\n withArray.with._locales = {\n columns: {\n id: false,\n _parentID: false,\n },\n with: {},\n }\n }\n currentArgs.with[`${path}${field.name}`] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n fields: field.fields,\n joinQuery,\n path: '',\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n })\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n const withSelect: Result = {\n columns: {\n id: false,\n order: false,\n parent: false,\n },\n orderBy: ({ order }, { asc }) => [asc(order)],\n }\n\n currentArgs.with[`${path}${field.name}`] = withSelect\n }\n\n break\n }\n\n case 'blocks':\n field.blocks.forEach((block) => {\n const blockKey = `_blocks_${block.slug}`\n\n if (!topLevelArgs[blockKey]) {\n const withBlock: Result = {\n columns: {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const tableName = adapter.tableNameMap.get(\n `${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {\n withBlock.with._locales = {\n with: {},\n }\n }\n topLevelArgs.with[blockKey] = withBlock\n\n traverseFields({\n _locales: withBlock.with._locales,\n adapter,\n currentArgs: withBlock,\n currentTableName: tableName,\n depth,\n fields: block.fields,\n joinQuery,\n path: '',\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n })\n }\n })\n\n break\n\n case 'group': {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path: `${path}${field.name}_`,\n tablePath: `${tablePath}${toSnakeCase(field.name)}_`,\n topLevelArgs,\n topLevelTableName,\n versions,\n })\n\n break\n }\n\n case 'join': {\n // when `joinsQuery` is false, do not join\n if (joinQuery === false) {\n break\n }\n\n const {\n limit: limitArg = 10,\n sort,\n where,\n } = joinQuery[`${path.replaceAll('_', '.')}${field.name}`] || {}\n let limit = limitArg\n\n if (limit !== 0) {\n // get an additional document and slice it later to determine if there is a next page\n limit += 1\n }\n\n const fields = adapter.payload.collections[field.collection].config.fields\n\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(field.collection))\n\n const joins: BuildQueryJoinAliases = []\n\n const buildQueryResult = buildQuery({\n adapter,\n fields,\n joins,\n locale,\n sort,\n tableName: joinCollectionTableName,\n where,\n })\n\n let subQueryWhere = buildQueryResult.where\n const orderBy = buildQueryResult.orderBy\n\n let joinLocalesCollectionTableName: string | undefined\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n // Handle hasMany _rels table\n if (field.hasMany) {\n const joinRelsCollectionTableName = `${joinCollectionTableName}${adapter.relationshipsSuffix}`\n\n if (field.localized) {\n joinLocalesCollectionTableName = joinRelsCollectionTableName\n }\n\n let columnReferenceToCurrentID: string\n\n if (versions) {\n columnReferenceToCurrentID = `${topLevelTableName.replace('_', '').replace(new RegExp(`${adapter.versionsSuffix}$`), '')}_id`\n } else {\n columnReferenceToCurrentID = `${topLevelTableName}_id`\n }\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinRelsCollectionTableName].parent,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n sql.raw(`\"${joinRelsCollectionTableName}\".\"${columnReferenceToCurrentID}\"`),\n currentIDColumn,\n ),\n eq(adapter.tables[joinRelsCollectionTableName].path, field.on),\n ),\n table: adapter.tables[joinRelsCollectionTableName],\n })\n } else {\n // Handle localized without hasMany\n\n const foreignColumn = field.on.replaceAll('.', '_')\n\n if (field.localized) {\n joinLocalesCollectionTableName = `${joinCollectionTableName}${adapter.localesSuffix}`\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinLocalesCollectionTableName]._parentID,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n adapter.tables[joinLocalesCollectionTableName][foreignColumn],\n currentIDColumn,\n ),\n ),\n table: adapter.tables[joinLocalesCollectionTableName],\n })\n // Handle without localized and without hasMany, just a condition append to where. With localized the inner join handles eq.\n } else {\n const constraint = eq(\n adapter.tables[joinCollectionTableName][foreignColumn],\n currentIDColumn,\n )\n\n if (subQueryWhere) {\n subQueryWhere = and(subQueryWhere, constraint)\n } else {\n subQueryWhere = constraint\n }\n }\n }\n\n const chainedMethods: ChainedMethods = []\n\n joins.forEach(({ type, condition, table }) => {\n chainedMethods.push({\n args: [table, condition],\n method: type ?? 'leftJoin',\n })\n })\n\n if (limit !== 0) {\n chainedMethods.push({\n args: [limit],\n method: 'limit',\n })\n }\n\n const db = adapter.drizzle as LibSQLDatabase\n\n const subQuery = chainMethods({\n methods: chainedMethods,\n query: db\n .select({\n id: adapter.tables[joinCollectionTableName].id,\n ...(joinLocalesCollectionTableName && {\n locale:\n adapter.tables[joinLocalesCollectionTableName].locale ||\n adapter.tables[joinLocalesCollectionTableName]._locale,\n }),\n })\n .from(adapter.tables[joinCollectionTableName])\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column))),\n })\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const jsonObjectSelect = field.localized\n ? sql.raw(\n `'_parentID', \"id\", '_locale', \"${adapter.tables[joinLocalesCollectionTableName].locale ? 'locale' : '_locale'}\"`,\n )\n : sql.raw(`'id', \"id\"`)\n\n if (adapter.name === 'sqlite') {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_group_array(json_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]')\n `.as(columnName)\n } else {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_agg(json_build_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]'::json)\n `.as(columnName)\n }\n\n break\n }\n\n default: {\n break\n }\n }\n }\n })\n\n return topLevelArgs\n}\n"],"names":["and","eq","sql","fieldAffectsData","fieldIsVirtual","tabHasName","toSnakeCase","buildQuery","chainMethods","traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","joinQuery","joins","locale","path","tablePath","topLevelArgs","topLevelTableName","versions","forEach","field","type","hasMany","relationTo","localized","with","name","tabs","tab","tabPath","tabTablePath","withArray","columns","_parentID","orderBy","_order","asc","arrayTableName","tableNameMap","get","arrayTableNameWithLocales","localesSuffix","tables","id","withSelect","order","parent","blocks","block","blockKey","slug","withBlock","tableName","limit","limitArg","sort","where","replaceAll","payload","collections","collection","config","joinCollectionTableName","buildQueryResult","subQueryWhere","joinLocalesCollectionTableName","currentIDColumn","joinRelsCollectionTableName","relationshipsSuffix","columnReferenceToCurrentID","replace","RegExp","versionsSuffix","push","condition","raw","on","table","foreignColumn","constraint","chainedMethods","args","method","db","drizzle","subQuery","methods","query","select","_locale","from","map","column","columnName","jsonObjectSelect","extras","as"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { Field, JoinQuery, SelectMode, SelectType } from 'payload'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { BuildQueryJoinAliases, ChainedMethods, DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\nimport buildQuery from '../queries/buildQuery.js'\nimport { chainMethods } from './chainMethods.js'\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n currentArgs: Result\n currentTableName: string\n depth?: number\n fields: Field[]\n joinQuery: JoinQuery\n joins?: BuildQueryJoinAliases\n locale?: string\n path: string\n select?: SelectType\n selectAllOnCurrentLevel?: boolean\n selectMode?: SelectMode\n tablePath: string\n topLevelArgs: Record<string, unknown>\n topLevelTableName: string\n versions?: boolean\n withinLocalizedField?: boolean\n withTabledFields: {\n numbers?: boolean\n rels?: boolean\n texts?: boolean\n }\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields,\n joinQuery = {},\n joins,\n locale,\n path,\n select,\n selectAllOnCurrentLevel = false,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField = false,\n withTabledFields,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\n if (fieldIsVirtual(field)) {\n return\n }\n\n // handle simple relationship\n if (\n depth > 0 &&\n (field.type === 'upload' || field.type === 'relationship') &&\n !field.hasMany &&\n typeof field.relationTo === 'string'\n ) {\n if (field.localized) {\n _locales.with[`${path}${field.name}`] = true\n } else {\n currentArgs.with[`${path}${field.name}`] = true\n }\n }\n\n if (field.type === 'collapsible' || field.type === 'row') {\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path,\n select,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n withTabledFields,\n })\n\n return\n }\n\n if (field.type === 'tabs') {\n field.tabs.forEach((tab) => {\n const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path\n const tabTablePath = tabHasName(tab) ? `${tablePath}${toSnakeCase(tab.name)}_` : tablePath\n\n const tabSelect = tabHasName(tab) ? select?.[tab.name] : select\n\n if (tabSelect === false) {\n return\n }\n\n let tabSelectAllOnCurrentLevel = selectAllOnCurrentLevel\n\n if (tabHasName(tab) && select && !tabSelectAllOnCurrentLevel) {\n tabSelectAllOnCurrentLevel =\n select[tab.name] === true ||\n (selectMode === 'exclude' && typeof select[tab.name] === 'undefined')\n }\n\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: tab.fields,\n joinQuery,\n joins,\n path: tabPath,\n select: typeof tabSelect === 'object' ? tabSelect : undefined,\n selectAllOnCurrentLevel: tabSelectAllOnCurrentLevel,\n selectMode,\n tablePath: tabTablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\n })\n })\n\n return\n }\n\n if (fieldAffectsData(field)) {\n switch (field.type) {\n case 'array': {\n const arraySelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && typeof arraySelect === 'undefined') ||\n (selectMode === 'exclude' && arraySelect === false)\n ) {\n break\n }\n }\n\n const withArray: Result = {\n columns:\n typeof arraySelect === 'object'\n ? {\n id: true,\n _order: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const arrayTableName = adapter.tableNameMap.get(\n `${currentTableName}_${tablePath}${toSnakeCase(field.name)}`,\n )\n\n if (typeof arraySelect === 'object') {\n if (adapter.tables[arrayTableName]._locale) {\n withArray.columns._locale = true\n }\n\n if (adapter.tables[arrayTableName]._uuid) {\n withArray.columns._uuid = true\n }\n }\n\n const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`\n\n if (adapter.tables[arrayTableNameWithLocales]) {\n withArray.with._locales = {\n columns:\n typeof arraySelect === 'object'\n ? {\n _locale: true,\n }\n : {\n id: false,\n _parentID: false,\n },\n with: {},\n }\n }\n\n currentArgs.with[`${path}${field.name}`] = withArray\n\n traverseFields({\n _locales: withArray.with._locales,\n adapter,\n currentArgs: withArray,\n currentTableName: arrayTableName,\n depth,\n fields: field.fields,\n joinQuery,\n path: '',\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof arraySelect === 'object' &&\n withArray.with._locales &&\n Object.keys(withArray.with._locales).length === 1\n ) {\n delete withArray.with._locales\n }\n\n break\n }\n\n case 'select': {\n if (field.hasMany) {\n if (select) {\n if (\n (selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n }\n\n const withSelect: Result = {\n columns: {\n id: false,\n order: false,\n parent: false,\n },\n orderBy: ({ order }, { asc }) => [asc(order)],\n }\n\n currentArgs.with[`${path}${field.name}`] = withSelect\n }\n\n break\n }\n\n case 'blocks': {\n const blocksSelect = selectAllOnCurrentLevel ? true : select?.[field.name]\n\n if (select) {\n if (\n (selectMode === 'include' && !blocksSelect) ||\n (selectMode === 'exclude' && blocksSelect === false)\n ) {\n break\n }\n }\n\n field.blocks.forEach((block) => {\n const blockKey = `_blocks_${block.slug}`\n\n let blockSelect: boolean | SelectType | undefined\n\n let blockSelectMode = selectMode\n\n if (selectMode === 'include' && blocksSelect === true) {\n blockSelect = true\n }\n\n if (typeof blocksSelect === 'object') {\n if (typeof blocksSelect[block.slug] === 'object') {\n blockSelect = blocksSelect[block.slug]\n } else if (\n (selectMode === 'include' && typeof blocksSelect[block.slug] === 'undefined') ||\n (selectMode === 'exclude' && blocksSelect[block.slug] === false)\n ) {\n blockSelect = {}\n blockSelectMode = 'include'\n } else if (selectMode === 'include' && blocksSelect[block.slug] === true) {\n blockSelect = true\n }\n }\n\n if (!topLevelArgs[blockKey]) {\n const withBlock: Result = {\n columns:\n typeof blockSelect === 'object'\n ? {\n id: true,\n _order: true,\n _path: true,\n }\n : {\n _parentID: false,\n },\n orderBy: ({ _order }, { asc }) => [asc(_order)],\n with: {},\n }\n\n const tableName = adapter.tableNameMap.get(\n `${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n if (typeof blockSelect === 'object') {\n if (adapter.tables[tableName]._locale) {\n withBlock.columns._locale = true\n }\n\n if (adapter.tables[tableName]._uuid) {\n withBlock.columns._uuid = true\n }\n }\n\n if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {\n withBlock.with._locales = {\n with: {},\n }\n\n if (typeof blockSelect === 'object') {\n withBlock.with._locales.columns = {\n _locale: true,\n }\n }\n }\n topLevelArgs.with[blockKey] = withBlock\n\n traverseFields({\n _locales: withBlock.with._locales,\n adapter,\n currentArgs: withBlock,\n currentTableName: tableName,\n depth,\n fields: block.fields,\n joinQuery,\n path: '',\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n tablePath: '',\n topLevelArgs,\n topLevelTableName,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n if (\n typeof blockSelect === 'object' &&\n withBlock.with._locales &&\n Object.keys(withBlock.with._locales.columns).length === 1\n ) {\n delete withBlock.with._locales\n }\n }\n })\n\n break\n }\n\n case 'group': {\n const groupSelect = select?.[field.name]\n\n if (groupSelect === false) {\n break\n }\n\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.fields,\n joinQuery,\n joins,\n path: `${path}${field.name}_`,\n select: typeof groupSelect === 'object' ? groupSelect : undefined,\n selectAllOnCurrentLevel:\n selectAllOnCurrentLevel ||\n groupSelect === true ||\n (selectMode === 'exclude' && typeof groupSelect === 'undefined'),\n selectMode,\n tablePath: `${tablePath}${toSnakeCase(field.name)}_`,\n topLevelArgs,\n topLevelTableName,\n versions,\n withinLocalizedField: withinLocalizedField || field.localized,\n withTabledFields,\n })\n\n break\n }\n\n case 'join': {\n // when `joinsQuery` is false, do not join\n if (joinQuery === false) {\n break\n }\n\n if (\n (select && selectMode === 'include' && !select[field.name]) ||\n (selectMode === 'exclude' && select[field.name] === false)\n ) {\n break\n }\n\n const {\n limit: limitArg = field.defaultLimit ?? 10,\n sort = field.defaultSort,\n where,\n } = joinQuery[`${path.replaceAll('_', '.')}${field.name}`] || {}\n let limit = limitArg\n\n if (limit !== 0) {\n // get an additional document and slice it later to determine if there is a next page\n limit += 1\n }\n\n const fields = adapter.payload.collections[field.collection].config.fields\n\n const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(field.collection))\n\n const joins: BuildQueryJoinAliases = []\n\n const buildQueryResult = buildQuery({\n adapter,\n fields,\n joins,\n locale,\n sort,\n tableName: joinCollectionTableName,\n where,\n })\n\n let subQueryWhere = buildQueryResult.where\n const orderBy = buildQueryResult.orderBy\n\n let joinLocalesCollectionTableName: string | undefined\n\n const currentIDColumn = versions\n ? adapter.tables[currentTableName].parent\n : adapter.tables[currentTableName].id\n\n // Handle hasMany _rels table\n if (field.hasMany) {\n const joinRelsCollectionTableName = `${joinCollectionTableName}${adapter.relationshipsSuffix}`\n\n if (field.localized) {\n joinLocalesCollectionTableName = joinRelsCollectionTableName\n }\n\n let columnReferenceToCurrentID: string\n\n if (versions) {\n columnReferenceToCurrentID = `${topLevelTableName\n .replace('_', '')\n .replace(new RegExp(`${adapter.versionsSuffix}$`), '')}_id`\n } else {\n columnReferenceToCurrentID = `${topLevelTableName}_id`\n }\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinRelsCollectionTableName].parent,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n sql.raw(`\"${joinRelsCollectionTableName}\".\"${columnReferenceToCurrentID}\"`),\n currentIDColumn,\n ),\n eq(adapter.tables[joinRelsCollectionTableName].path, field.on),\n ),\n table: adapter.tables[joinRelsCollectionTableName],\n })\n } else {\n // Handle localized without hasMany\n\n const foreignColumn = field.on.replaceAll('.', '_')\n\n if (field.localized) {\n joinLocalesCollectionTableName = `${joinCollectionTableName}${adapter.localesSuffix}`\n\n joins.push({\n type: 'innerJoin',\n condition: and(\n eq(\n adapter.tables[joinLocalesCollectionTableName]._parentID,\n adapter.tables[joinCollectionTableName].id,\n ),\n eq(\n adapter.tables[joinLocalesCollectionTableName][foreignColumn],\n currentIDColumn,\n ),\n ),\n table: adapter.tables[joinLocalesCollectionTableName],\n })\n // Handle without localized and without hasMany, just a condition append to where. With localized the inner join handles eq.\n } else {\n const constraint = eq(\n adapter.tables[joinCollectionTableName][foreignColumn],\n currentIDColumn,\n )\n\n if (subQueryWhere) {\n subQueryWhere = and(subQueryWhere, constraint)\n } else {\n subQueryWhere = constraint\n }\n }\n }\n\n const chainedMethods: ChainedMethods = []\n\n joins.forEach(({ type, condition, table }) => {\n chainedMethods.push({\n args: [table, condition],\n method: type ?? 'leftJoin',\n })\n })\n\n if (limit !== 0) {\n chainedMethods.push({\n args: [limit],\n method: 'limit',\n })\n }\n\n const db = adapter.drizzle as LibSQLDatabase\n\n const subQuery = chainMethods({\n methods: chainedMethods,\n query: db\n .select({\n id: adapter.tables[joinCollectionTableName].id,\n ...(joinLocalesCollectionTableName && {\n locale:\n adapter.tables[joinLocalesCollectionTableName].locale ||\n adapter.tables[joinLocalesCollectionTableName]._locale,\n }),\n })\n .from(adapter.tables[joinCollectionTableName])\n .where(subQueryWhere)\n .orderBy(() => orderBy.map(({ column, order }) => order(column))),\n })\n\n const columnName = `${path.replaceAll('.', '_')}${field.name}`\n\n const jsonObjectSelect = field.localized\n ? sql.raw(\n `'_parentID', \"id\", '_locale', \"${adapter.tables[joinLocalesCollectionTableName].locale ? 'locale' : '_locale'}\"`,\n )\n : sql.raw(`'id', \"id\"`)\n\n if (adapter.name === 'sqlite') {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_group_array(json_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]')\n `.as(columnName)\n } else {\n currentArgs.extras[columnName] = sql`\n COALESCE((\n SELECT json_agg(json_build_object(${jsonObjectSelect}))\n FROM (\n ${subQuery}\n ) AS ${sql.raw(`${columnName}_sub`)}\n ), '[]'::json)\n `.as(columnName)\n }\n\n break\n }\n\n default: {\n if (!select && !selectAllOnCurrentLevel) {\n break\n }\n\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && select[field.name] === true) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n const fieldPath = `${path}${field.name}`\n\n if ((field.localized || withinLocalizedField) && _locales) {\n _locales.columns[fieldPath] = true\n } else if (adapter.tables[currentTableName]?.[fieldPath]) {\n currentArgs.columns[fieldPath] = true\n }\n\n if (\n !withTabledFields.rels &&\n field.type === 'relationship' &&\n (field.hasMany || Array.isArray(field.relationTo))\n ) {\n withTabledFields.rels = true\n }\n\n if (!withTabledFields.numbers && field.type === 'number' && field.hasMany) {\n withTabledFields.numbers = true\n }\n\n if (!withTabledFields.texts && field.type === 'text' && field.hasMany) {\n withTabledFields.texts = true\n }\n }\n\n break\n }\n }\n }\n })\n\n return topLevelArgs\n}\n"],"names":["and","eq","sql","fieldAffectsData","fieldIsVirtual","tabHasName","toSnakeCase","buildQuery","chainMethods","traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","joinQuery","joins","locale","path","select","selectAllOnCurrentLevel","selectMode","tablePath","topLevelArgs","topLevelTableName","versions","withinLocalizedField","withTabledFields","forEach","field","type","hasMany","relationTo","localized","with","name","tabs","tab","tabPath","tabTablePath","tabSelect","tabSelectAllOnCurrentLevel","undefined","arraySelect","withArray","columns","id","_order","_parentID","orderBy","asc","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","Object","keys","length","withSelect","order","parent","blocksSelect","blocks","block","blockKey","slug","blockSelect","blockSelectMode","withBlock","_path","tableName","groupSelect","limit","limitArg","defaultLimit","sort","defaultSort","where","replaceAll","payload","collections","collection","config","joinCollectionTableName","buildQueryResult","subQueryWhere","joinLocalesCollectionTableName","currentIDColumn","joinRelsCollectionTableName","relationshipsSuffix","columnReferenceToCurrentID","replace","RegExp","versionsSuffix","push","condition","raw","on","table","foreignColumn","constraint","chainedMethods","args","method","db","drizzle","subQuery","methods","query","from","map","column","columnName","jsonObjectSelect","extras","as","fieldPath","rels","Array","isArray","numbers","texts"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"find.d.ts","sourceRoot":"","sources":["../src/find.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAA6C,MAAM,SAAS,CAAA;AAQ9E,eAAO,MAAM,IAAI,EAAE,IAgClB,CAAA"}
1
+ {"version":3,"file":"find.d.ts","sourceRoot":"","sources":["../src/find.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAA6C,MAAM,SAAS,CAAA;AAQ9E,eAAO,MAAM,IAAI,EAAE,IAkClB,CAAA"}
package/dist/find.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import toSnakeCase from 'to-snake-case';
2
2
  import { findMany } from './find/findMany.js';
3
- export const find = async function find({ collection, joins, limit, locale, page = 1, pagination, req = {}, sort: sortArg, where }) {
3
+ export const find = async function find({ collection, joins, limit, locale, page = 1, pagination, req = {}, select, sort: sortArg, where }) {
4
4
  const collectionConfig = this.payload.collections[collection].config;
5
5
  const sort = sortArg !== undefined && sortArg !== null ? sortArg : collectionConfig.defaultSort;
6
6
  const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug));
@@ -13,6 +13,7 @@ export const find = async function find({ collection, joins, limit, locale, page
13
13
  page,
14
14
  pagination,
15
15
  req,
16
+ select,
16
17
  sort,
17
18
  tableName,
18
19
  where
package/dist/find.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/find.ts"],"sourcesContent":["import type { Find, PayloadRequest, SanitizedCollectionConfig } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const find: Find = async function find(\n this: DrizzleAdapter,\n {\n collection,\n joins,\n limit,\n locale,\n page = 1,\n pagination,\n req = {} as PayloadRequest,\n sort: sortArg,\n where,\n },\n) {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n const sort = sortArg !== undefined && sortArg !== null ? sortArg : collectionConfig.defaultSort\n\n const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug))\n\n return findMany({\n adapter: this,\n fields: collectionConfig.fields,\n joins,\n limit,\n locale,\n page,\n pagination,\n req,\n sort,\n tableName,\n where,\n })\n}\n"],"names":["toSnakeCase","findMany","find","collection","joins","limit","locale","page","pagination","req","sort","sortArg","where","collectionConfig","payload","collections","config","undefined","defaultSort","tableName","tableNameMap","get","slug","adapter","fields"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,OAAa,eAAeA,KAEvC,EACEC,UAAU,EACVC,KAAK,EACLC,KAAK,EACLC,MAAM,EACNC,OAAO,CAAC,EACRC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,MAAMC,OAAO,EACbC,KAAK,EACN;IAED,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACZ,WAAW,CAACa,MAAM;IAC/F,MAAMN,OAAOC,YAAYM,aAAaN,YAAY,OAAOA,UAAUE,iBAAiBK,WAAW;IAE/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACrB,YAAYa,iBAAiBS,IAAI;IAEzE,OAAOrB,SAAS;QACdsB,SAAS,IAAI;QACbC,QAAQX,iBAAiBW,MAAM;QAC/BpB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAS;QACAP;IACF;AACF,EAAC"}
1
+ {"version":3,"sources":["../src/find.ts"],"sourcesContent":["import type { Find, PayloadRequest, SanitizedCollectionConfig } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const find: Find = async function find(\n this: DrizzleAdapter,\n {\n collection,\n joins,\n limit,\n locale,\n page = 1,\n pagination,\n req = {} as PayloadRequest,\n select,\n sort: sortArg,\n where,\n },\n) {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n const sort = sortArg !== undefined && sortArg !== null ? sortArg : collectionConfig.defaultSort\n\n const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug))\n\n return findMany({\n adapter: this,\n fields: collectionConfig.fields,\n joins,\n limit,\n locale,\n page,\n pagination,\n req,\n select,\n sort,\n tableName,\n where,\n })\n}\n"],"names":["toSnakeCase","findMany","find","collection","joins","limit","locale","page","pagination","req","select","sort","sortArg","where","collectionConfig","payload","collections","config","undefined","defaultSort","tableName","tableNameMap","get","slug","adapter","fields"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,OAAa,eAAeA,KAEvC,EACEC,UAAU,EACVC,KAAK,EACLC,KAAK,EACLC,MAAM,EACNC,OAAO,CAAC,EACRC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,MAAM,EACNC,MAAMC,OAAO,EACbC,KAAK,EACN;IAED,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACb,WAAW,CAACc,MAAM;IAC/F,MAAMN,OAAOC,YAAYM,aAAaN,YAAY,OAAOA,UAAUE,iBAAiBK,WAAW;IAE/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACtB,YAAYc,iBAAiBS,IAAI;IAEzE,OAAOtB,SAAS;QACduB,SAAS,IAAI;QACbC,QAAQX,iBAAiBW,MAAM;QAC/BrB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAS;QACAP;IACF;AACF,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"findGlobal.d.ts","sourceRoot":"","sources":["../src/findGlobal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAQzC,eAAO,MAAM,UAAU,EAAE,UA2BxB,CAAA"}
1
+ {"version":3,"file":"findGlobal.d.ts","sourceRoot":"","sources":["../src/findGlobal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAQzC,eAAO,MAAM,UAAU,EAAE,UA4BxB,CAAA"}
@@ -1,6 +1,6 @@
1
1
  import toSnakeCase from 'to-snake-case';
2
2
  import { findMany } from './find/findMany.js';
3
- export const findGlobal = async function findGlobal({ slug, locale, req, where }) {
3
+ export const findGlobal = async function findGlobal({ slug, locale, req, select, where }) {
4
4
  const globalConfig = this.payload.globals.config.find((config)=>config.slug === slug);
5
5
  const tableName = this.tableNameMap.get(toSnakeCase(globalConfig.slug));
6
6
  const { docs: [doc] } = await findMany({
@@ -10,6 +10,7 @@ export const findGlobal = async function findGlobal({ slug, locale, req, where }
10
10
  locale,
11
11
  pagination: false,
12
12
  req,
13
+ select,
13
14
  tableName,
14
15
  where
15
16
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/findGlobal.ts"],"sourcesContent":["import type { FindGlobal } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const findGlobal: FindGlobal = async function findGlobal(\n this: DrizzleAdapter,\n { slug, locale, req, where },\n) {\n const globalConfig = this.payload.globals.config.find((config) => config.slug === slug)\n\n const tableName = this.tableNameMap.get(toSnakeCase(globalConfig.slug))\n\n const {\n docs: [doc],\n } = await findMany({\n adapter: this,\n fields: globalConfig.fields,\n limit: 1,\n locale,\n pagination: false,\n req,\n tableName,\n where,\n })\n\n if (doc) {\n doc.globalType = slug\n return doc\n }\n\n return {}\n}\n"],"names":["toSnakeCase","findMany","findGlobal","slug","locale","req","where","globalConfig","payload","globals","config","find","tableName","tableNameMap","get","docs","doc","adapter","fields","limit","pagination","globalType"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,aAAyB,eAAeA,WAEnD,EAAEC,IAAI,EAAEC,MAAM,EAAEC,GAAG,EAAEC,KAAK,EAAE;IAE5B,MAAMC,eAAe,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAAC,CAACD,SAAWA,OAAOP,IAAI,KAAKA;IAElF,MAAMS,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACd,YAAYO,aAAaJ,IAAI;IAErE,MAAM,EACJY,MAAM,CAACC,IAAI,EACZ,GAAG,MAAMf,SAAS;QACjBgB,SAAS,IAAI;QACbC,QAAQX,aAAaW,MAAM;QAC3BC,OAAO;QACPf;QACAgB,YAAY;QACZf;QACAO;QACAN;IACF;IAEA,IAAIU,KAAK;QACPA,IAAIK,UAAU,GAAGlB;QACjB,OAAOa;IACT;IAEA,OAAO,CAAC;AACV,EAAC"}
1
+ {"version":3,"sources":["../src/findGlobal.ts"],"sourcesContent":["import type { FindGlobal } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport const findGlobal: FindGlobal = async function findGlobal(\n this: DrizzleAdapter,\n { slug, locale, req, select, where },\n) {\n const globalConfig = this.payload.globals.config.find((config) => config.slug === slug)\n\n const tableName = this.tableNameMap.get(toSnakeCase(globalConfig.slug))\n\n const {\n docs: [doc],\n } = await findMany({\n adapter: this,\n fields: globalConfig.fields,\n limit: 1,\n locale,\n pagination: false,\n req,\n select,\n tableName,\n where,\n })\n\n if (doc) {\n doc.globalType = slug\n return doc\n }\n\n return {}\n}\n"],"names":["toSnakeCase","findMany","findGlobal","slug","locale","req","select","where","globalConfig","payload","globals","config","find","tableName","tableNameMap","get","docs","doc","adapter","fields","limit","pagination","globalType"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,aAAyB,eAAeA,WAEnD,EAAEC,IAAI,EAAEC,MAAM,EAAEC,GAAG,EAAEC,MAAM,EAAEC,KAAK,EAAE;IAEpC,MAAMC,eAAe,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAAC,CAACD,SAAWA,OAAOR,IAAI,KAAKA;IAElF,MAAMU,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACf,YAAYQ,aAAaL,IAAI;IAErE,MAAM,EACJa,MAAM,CAACC,IAAI,EACZ,GAAG,MAAMhB,SAAS;QACjBiB,SAAS,IAAI;QACbC,QAAQX,aAAaW,MAAM;QAC3BC,OAAO;QACPhB;QACAiB,YAAY;QACZhB;QACAC;QACAO;QACAN;IACF;IAEA,IAAIU,KAAK;QACPA,IAAIK,UAAU,GAAGnB;QACjB,OAAOc;IACT;IAEA,OAAO,CAAC;AACV,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"findGlobalVersions.d.ts","sourceRoot":"","sources":["../src/findGlobalVersions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAyC,MAAM,SAAS,CAAA;AASxF,eAAO,MAAM,kBAAkB,EAAE,kBAsChC,CAAA"}
1
+ {"version":3,"file":"findGlobalVersions.d.ts","sourceRoot":"","sources":["../src/findGlobalVersions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAyC,MAAM,SAAS,CAAA;AASxF,eAAO,MAAM,kBAAkB,EAAE,kBAwChC,CAAA"}
@@ -1,7 +1,7 @@
1
1
  import { buildVersionGlobalFields } from 'payload';
2
2
  import toSnakeCase from 'to-snake-case';
3
3
  import { findMany } from './find/findMany.js';
4
- export const findGlobalVersions = async function findGlobalVersions({ global, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
4
+ export const findGlobalVersions = async function findGlobalVersions({ global, limit, locale, page, pagination, req = {}, select, skip, sort: sortArg, where }) {
5
5
  const globalConfig = this.payload.globals.config.find(({ slug })=>slug === global);
6
6
  const sort = sortArg !== undefined && sortArg !== null ? sortArg : '-createdAt';
7
7
  const tableName = this.tableNameMap.get(`_${toSnakeCase(globalConfig.slug)}${this.versionsSuffix}`);
@@ -14,6 +14,7 @@ export const findGlobalVersions = async function findGlobalVersions({ global, li
14
14
  page,
15
15
  pagination,
16
16
  req,
17
+ select,
17
18
  skip,
18
19
  sort,
19
20
  tableName,
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/findGlobalVersions.ts"],"sourcesContent":["import type { FindGlobalVersions, PayloadRequest, SanitizedGlobalConfig } from 'payload'\n\nimport { buildVersionGlobalFields } 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 findGlobalVersions: FindGlobalVersions = async function findGlobalVersions(\n this: DrizzleAdapter,\n {\n global,\n limit,\n locale,\n page,\n pagination,\n req = {} as PayloadRequest,\n skip,\n sort: sortArg,\n where,\n },\n) {\n const globalConfig: SanitizedGlobalConfig = this.payload.globals.config.find(\n ({ slug }) => slug === global,\n )\n const sort = sortArg !== undefined && sortArg !== null ? sortArg : '-createdAt'\n\n const tableName = this.tableNameMap.get(\n `_${toSnakeCase(globalConfig.slug)}${this.versionsSuffix}`,\n )\n\n const fields = buildVersionGlobalFields(this.payload.config, globalConfig)\n\n return findMany({\n adapter: this,\n fields,\n limit,\n locale,\n page,\n pagination,\n req,\n skip,\n sort,\n tableName,\n where,\n })\n}\n"],"names":["buildVersionGlobalFields","toSnakeCase","findMany","findGlobalVersions","global","limit","locale","page","pagination","req","skip","sort","sortArg","where","globalConfig","payload","globals","config","find","slug","undefined","tableName","tableNameMap","get","versionsSuffix","fields","adapter"],"mappings":"AAEA,SAASA,wBAAwB,QAAQ,UAAS;AAClD,OAAOC,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,qBAAyC,eAAeA,mBAEnE,EACEC,MAAM,EACNC,KAAK,EACLC,MAAM,EACNC,IAAI,EACJC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,IAAI,EACJC,MAAMC,OAAO,EACbC,KAAK,EACN;IAED,MAAMC,eAAsC,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAC1E,CAAC,EAAEC,IAAI,EAAE,GAAKA,SAASf;IAEzB,MAAMO,OAAOC,YAAYQ,aAAaR,YAAY,OAAOA,UAAU;IAEnE,MAAMS,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CACrC,CAAC,CAAC,EAAEtB,YAAYa,aAAaK,IAAI,EAAE,EAAE,IAAI,CAACK,cAAc,CAAC,CAAC;IAG5D,MAAMC,SAASzB,yBAAyB,IAAI,CAACe,OAAO,CAACE,MAAM,EAAEH;IAE7D,OAAOZ,SAAS;QACdwB,SAAS,IAAI;QACbD;QACApB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAU;QACAR;IACF;AACF,EAAC"}
1
+ {"version":3,"sources":["../src/findGlobalVersions.ts"],"sourcesContent":["import type { FindGlobalVersions, PayloadRequest, SanitizedGlobalConfig } from 'payload'\n\nimport { buildVersionGlobalFields } 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 findGlobalVersions: FindGlobalVersions = async function findGlobalVersions(\n this: DrizzleAdapter,\n {\n global,\n limit,\n locale,\n page,\n pagination,\n req = {} as PayloadRequest,\n select,\n skip,\n sort: sortArg,\n where,\n },\n) {\n const globalConfig: SanitizedGlobalConfig = this.payload.globals.config.find(\n ({ slug }) => slug === global,\n )\n const sort = sortArg !== undefined && sortArg !== null ? sortArg : '-createdAt'\n\n const tableName = this.tableNameMap.get(\n `_${toSnakeCase(globalConfig.slug)}${this.versionsSuffix}`,\n )\n\n const fields = buildVersionGlobalFields(this.payload.config, globalConfig)\n\n return findMany({\n adapter: this,\n fields,\n limit,\n locale,\n page,\n pagination,\n req,\n select,\n skip,\n sort,\n tableName,\n where,\n })\n}\n"],"names":["buildVersionGlobalFields","toSnakeCase","findMany","findGlobalVersions","global","limit","locale","page","pagination","req","select","skip","sort","sortArg","where","globalConfig","payload","globals","config","find","slug","undefined","tableName","tableNameMap","get","versionsSuffix","fields","adapter"],"mappings":"AAEA,SAASA,wBAAwB,QAAQ,UAAS;AAClD,OAAOC,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,MAAMC,qBAAyC,eAAeA,mBAEnE,EACEC,MAAM,EACNC,KAAK,EACLC,MAAM,EACNC,IAAI,EACJC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,MAAM,EACNC,IAAI,EACJC,MAAMC,OAAO,EACbC,KAAK,EACN;IAED,MAAMC,eAAsC,IAAI,CAACC,OAAO,CAACC,OAAO,CAACC,MAAM,CAACC,IAAI,CAC1E,CAAC,EAAEC,IAAI,EAAE,GAAKA,SAAShB;IAEzB,MAAMQ,OAAOC,YAAYQ,aAAaR,YAAY,OAAOA,UAAU;IAEnE,MAAMS,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CACrC,CAAC,CAAC,EAAEvB,YAAYc,aAAaK,IAAI,EAAE,EAAE,IAAI,CAACK,cAAc,CAAC,CAAC;IAG5D,MAAMC,SAAS1B,yBAAyB,IAAI,CAACgB,OAAO,CAACE,MAAM,EAAEH;IAE7D,OAAOb,SAAS;QACdyB,SAAS,IAAI;QACbD;QACArB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAU;QACAR;IACF;AACF,EAAC"}
package/dist/findOne.d.ts CHANGED
@@ -1,4 +1,4 @@
1
1
  import type { FindOneArgs, TypeWithID } from 'payload';
2
2
  import type { DrizzleAdapter } from './types.js';
3
- export declare function findOne<T extends TypeWithID>(this: DrizzleAdapter, { collection, joins, locale, req, where }: FindOneArgs): Promise<T>;
3
+ export declare function findOne<T extends TypeWithID>(this: DrizzleAdapter, { collection, joins, locale, req, select, where }: FindOneArgs): Promise<T>;
4
4
  //# sourceMappingURL=findOne.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"findOne.d.ts","sourceRoot":"","sources":["../src/findOne.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAA6C,UAAU,EAAE,MAAM,SAAS,CAAA;AAIjG,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAIhD,wBAAsB,OAAO,CAAC,CAAC,SAAS,UAAU,EAChD,IAAI,EAAE,cAAc,EACpB,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,GAA0B,EAAE,KAAK,EAAE,EAAE,WAAW,GAC5E,OAAO,CAAC,CAAC,CAAC,CAoBZ"}
1
+ {"version":3,"file":"findOne.d.ts","sourceRoot":"","sources":["../src/findOne.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAA6C,UAAU,EAAE,MAAM,SAAS,CAAA;AAIjG,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAIhD,wBAAsB,OAAO,CAAC,CAAC,SAAS,UAAU,EAChD,IAAI,EAAE,cAAc,EACpB,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,GAA0B,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,WAAW,GACpF,OAAO,CAAC,CAAC,CAAC,CAqBZ"}
package/dist/findOne.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import toSnakeCase from 'to-snake-case';
2
2
  import { findMany } from './find/findMany.js';
3
- export async function findOne({ collection, joins, locale, req = {}, where }) {
3
+ export async function findOne({ collection, joins, locale, req = {}, select, where }) {
4
4
  const collectionConfig = this.payload.collections[collection].config;
5
5
  const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug));
6
6
  const { docs } = await findMany({
@@ -12,6 +12,7 @@ export async function findOne({ collection, joins, locale, req = {}, where }) {
12
12
  page: 1,
13
13
  pagination: false,
14
14
  req,
15
+ select,
15
16
  sort: undefined,
16
17
  tableName,
17
18
  where
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/findOne.ts"],"sourcesContent":["import type { FindOneArgs, PayloadRequest, SanitizedCollectionConfig, TypeWithID } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport async function findOne<T extends TypeWithID>(\n this: DrizzleAdapter,\n { collection, joins, locale, req = {} as PayloadRequest, where }: FindOneArgs,\n): Promise<T> {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n\n const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug))\n\n const { docs } = await findMany({\n adapter: this,\n fields: collectionConfig.fields,\n joins,\n limit: 1,\n locale,\n page: 1,\n pagination: false,\n req,\n sort: undefined,\n tableName,\n where,\n })\n\n return docs?.[0] || null\n}\n"],"names":["toSnakeCase","findMany","findOne","collection","joins","locale","req","where","collectionConfig","payload","collections","config","tableName","tableNameMap","get","slug","docs","adapter","fields","limit","page","pagination","sort","undefined"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,eAAeC,QAEpB,EAAEC,UAAU,EAAEC,KAAK,EAAEC,MAAM,EAAEC,MAAM,CAAC,CAAmB,EAAEC,KAAK,EAAe;IAE7E,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACP,WAAW,CAACQ,MAAM;IAE/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACd,YAAYQ,iBAAiBO,IAAI;IAEzE,MAAM,EAAEC,IAAI,EAAE,GAAG,MAAMf,SAAS;QAC9BgB,SAAS,IAAI;QACbC,QAAQV,iBAAiBU,MAAM;QAC/Bd;QACAe,OAAO;QACPd;QACAe,MAAM;QACNC,YAAY;QACZf;QACAgB,MAAMC;QACNX;QACAL;IACF;IAEA,OAAOS,MAAM,CAAC,EAAE,IAAI;AACtB"}
1
+ {"version":3,"sources":["../src/findOne.ts"],"sourcesContent":["import type { FindOneArgs, PayloadRequest, SanitizedCollectionConfig, TypeWithID } from 'payload'\n\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from './types.js'\n\nimport { findMany } from './find/findMany.js'\n\nexport async function findOne<T extends TypeWithID>(\n this: DrizzleAdapter,\n { collection, joins, locale, req = {} as PayloadRequest, select, where }: FindOneArgs,\n): Promise<T> {\n const collectionConfig: SanitizedCollectionConfig = this.payload.collections[collection].config\n\n const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug))\n\n const { docs } = await findMany({\n adapter: this,\n fields: collectionConfig.fields,\n joins,\n limit: 1,\n locale,\n page: 1,\n pagination: false,\n req,\n select,\n sort: undefined,\n tableName,\n where,\n })\n\n return docs?.[0] || null\n}\n"],"names":["toSnakeCase","findMany","findOne","collection","joins","locale","req","select","where","collectionConfig","payload","collections","config","tableName","tableNameMap","get","slug","docs","adapter","fields","limit","page","pagination","sort","undefined"],"mappings":"AAEA,OAAOA,iBAAiB,gBAAe;AAIvC,SAASC,QAAQ,QAAQ,qBAAoB;AAE7C,OAAO,eAAeC,QAEpB,EAAEC,UAAU,EAAEC,KAAK,EAAEC,MAAM,EAAEC,MAAM,CAAC,CAAmB,EAAEC,MAAM,EAAEC,KAAK,EAAe;IAErF,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACR,WAAW,CAACS,MAAM;IAE/F,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACf,YAAYS,iBAAiBO,IAAI;IAEzE,MAAM,EAAEC,IAAI,EAAE,GAAG,MAAMhB,SAAS;QAC9BiB,SAAS,IAAI;QACbC,QAAQV,iBAAiBU,MAAM;QAC/Bf;QACAgB,OAAO;QACPf;QACAgB,MAAM;QACNC,YAAY;QACZhB;QACAC;QACAgB,MAAMC;QACNX;QACAL;IACF;IAEA,OAAOS,MAAM,CAAC,EAAE,IAAI;AACtB"}
@@ -1 +1 @@
1
- {"version":3,"file":"findVersions.d.ts","sourceRoot":"","sources":["../src/findVersions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAA6C,MAAM,SAAS,CAAA;AAStF,eAAO,MAAM,YAAY,EAAE,YAoC1B,CAAA"}
1
+ {"version":3,"file":"findVersions.d.ts","sourceRoot":"","sources":["../src/findVersions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAA6C,MAAM,SAAS,CAAA;AAStF,eAAO,MAAM,YAAY,EAAE,YAsC1B,CAAA"}
@@ -1,7 +1,7 @@
1
1
  import { buildVersionCollectionFields } from 'payload';
2
2
  import toSnakeCase from 'to-snake-case';
3
3
  import { findMany } from './find/findMany.js';
4
- export const findVersions = async function findVersions({ collection, limit, locale, page, pagination, req = {}, skip, sort: sortArg, where }) {
4
+ export const findVersions = async function findVersions({ collection, limit, locale, page, pagination, req = {}, select, skip, sort: sortArg, where }) {
5
5
  const collectionConfig = this.payload.collections[collection].config;
6
6
  const sort = sortArg !== undefined && sortArg !== null ? sortArg : collectionConfig.defaultSort;
7
7
  const tableName = this.tableNameMap.get(`_${toSnakeCase(collectionConfig.slug)}${this.versionsSuffix}`);
@@ -14,6 +14,7 @@ export const findVersions = async function findVersions({ collection, limit, loc
14
14
  page,
15
15
  pagination,
16
16
  req,
17
+ select,
17
18
  skip,
18
19
  sort,
19
20
  tableName,