@payloadcms/drizzle 3.0.0-canary.ff8c8fd → 3.0.0

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 (291) hide show
  1. package/dist/count.d.ts.map +1 -1
  2. package/dist/count.js +1 -1
  3. package/dist/count.js.map +1 -1
  4. package/dist/countGlobalVersions.d.ts +3 -0
  5. package/dist/countGlobalVersions.d.ts.map +1 -0
  6. package/dist/countGlobalVersions.js +27 -0
  7. package/dist/countGlobalVersions.js.map +1 -0
  8. package/dist/countVersions.d.ts +3 -0
  9. package/dist/countVersions.d.ts.map +1 -0
  10. package/dist/countVersions.js +27 -0
  11. package/dist/countVersions.js.map +1 -0
  12. package/dist/create.d.ts.map +1 -1
  13. package/dist/create.js +2 -1
  14. package/dist/create.js.map +1 -1
  15. package/dist/createGlobalVersion.d.ts +1 -1
  16. package/dist/createGlobalVersion.d.ts.map +1 -1
  17. package/dist/createGlobalVersion.js +7 -2
  18. package/dist/createGlobalVersion.js.map +1 -1
  19. package/dist/createTableName.d.ts.map +1 -1
  20. package/dist/createTableName.js +6 -2
  21. package/dist/createTableName.js.map +1 -1
  22. package/dist/createVersion.d.ts +1 -1
  23. package/dist/createVersion.d.ts.map +1 -1
  24. package/dist/createVersion.js +22 -14
  25. package/dist/createVersion.js.map +1 -1
  26. package/dist/deleteOne.d.ts.map +1 -1
  27. package/dist/deleteOne.js +6 -3
  28. package/dist/deleteOne.js.map +1 -1
  29. package/dist/deleteVersions.js +1 -1
  30. package/dist/deleteVersions.js.map +1 -1
  31. package/dist/destroy.d.ts.map +1 -1
  32. package/dist/destroy.js +3 -1
  33. package/dist/destroy.js.map +1 -1
  34. package/dist/exports/postgres.d.ts +2 -1
  35. package/dist/exports/postgres.d.ts.map +1 -1
  36. package/dist/exports/postgres.js +2 -1
  37. package/dist/exports/postgres.js.map +1 -1
  38. package/dist/find/buildFindManyArgs.d.ts +15 -7
  39. package/dist/find/buildFindManyArgs.d.ts.map +1 -1
  40. package/dist/find/buildFindManyArgs.js +40 -17
  41. package/dist/find/buildFindManyArgs.js.map +1 -1
  42. package/dist/find/findMany.d.ts +2 -1
  43. package/dist/find/findMany.d.ts.map +1 -1
  44. package/dist/find/findMany.js +12 -7
  45. package/dist/find/findMany.js.map +1 -1
  46. package/dist/find/traverseFields.d.ts +18 -4
  47. package/dist/find/traverseFields.d.ts.map +1 -1
  48. package/dist/find/traverseFields.js +358 -68
  49. package/dist/find/traverseFields.js.map +1 -1
  50. package/dist/find.d.ts.map +1 -1
  51. package/dist/find.js +4 -2
  52. package/dist/find.js.map +1 -1
  53. package/dist/findGlobal.d.ts.map +1 -1
  54. package/dist/findGlobal.js +2 -1
  55. package/dist/findGlobal.js.map +1 -1
  56. package/dist/findGlobalVersions.d.ts.map +1 -1
  57. package/dist/findGlobalVersions.js +4 -3
  58. package/dist/findGlobalVersions.js.map +1 -1
  59. package/dist/findMigrationDir.d.ts.map +1 -1
  60. package/dist/findMigrationDir.js +3 -1
  61. package/dist/findMigrationDir.js.map +1 -1
  62. package/dist/findOne.d.ts +1 -1
  63. package/dist/findOne.d.ts.map +1 -1
  64. package/dist/findOne.js +3 -1
  65. package/dist/findOne.js.map +1 -1
  66. package/dist/findVersions.d.ts.map +1 -1
  67. package/dist/findVersions.js +4 -3
  68. package/dist/findVersions.js.map +1 -1
  69. package/dist/index.d.ts +5 -0
  70. package/dist/index.d.ts.map +1 -1
  71. package/dist/index.js +5 -0
  72. package/dist/index.js.map +1 -1
  73. package/dist/migrate.d.ts.map +1 -1
  74. package/dist/migrate.js +4 -0
  75. package/dist/migrate.js.map +1 -1
  76. package/dist/migrateDown.d.ts.map +1 -1
  77. package/dist/migrateDown.js +1 -1
  78. package/dist/migrateDown.js.map +1 -1
  79. package/dist/migrateFresh.d.ts.map +1 -1
  80. package/dist/migrateFresh.js +4 -0
  81. package/dist/migrateFresh.js.map +1 -1
  82. package/dist/migrateRefresh.d.ts.map +1 -1
  83. package/dist/migrateRefresh.js +2 -1
  84. package/dist/migrateRefresh.js.map +1 -1
  85. package/dist/migrateReset.d.ts.map +1 -1
  86. package/dist/migrateReset.js +5 -3
  87. package/dist/migrateReset.js.map +1 -1
  88. package/dist/migrateStatus.js +0 -1
  89. package/dist/migrateStatus.js.map +1 -1
  90. package/dist/postgres/countDistinct.d.ts.map +1 -1
  91. package/dist/postgres/countDistinct.js +2 -3
  92. package/dist/postgres/countDistinct.js.map +1 -1
  93. package/dist/postgres/createDatabase.d.ts +14 -0
  94. package/dist/postgres/createDatabase.d.ts.map +1 -0
  95. package/dist/postgres/createDatabase.js +76 -0
  96. package/dist/postgres/createDatabase.js.map +1 -0
  97. package/dist/postgres/createExtensions.d.ts +3 -0
  98. package/dist/postgres/createExtensions.d.ts.map +1 -0
  99. package/dist/postgres/createExtensions.js +16 -0
  100. package/dist/postgres/createExtensions.js.map +1 -0
  101. package/dist/postgres/createJSONQuery/convertPathToJSONTraversal.d.ts.map +1 -1
  102. package/dist/postgres/createJSONQuery/convertPathToJSONTraversal.js +3 -1
  103. package/dist/postgres/createJSONQuery/convertPathToJSONTraversal.js.map +1 -1
  104. package/dist/postgres/createJSONQuery/index.d.ts +2 -9
  105. package/dist/postgres/createJSONQuery/index.d.ts.map +1 -1
  106. package/dist/postgres/createJSONQuery/index.js +34 -46
  107. package/dist/postgres/createJSONQuery/index.js.map +1 -1
  108. package/dist/postgres/createMigration.d.ts.map +1 -1
  109. package/dist/postgres/createMigration.js +1 -5
  110. package/dist/postgres/createMigration.js.map +1 -1
  111. package/dist/postgres/defaultSnapshot.d.ts.map +1 -1
  112. package/dist/postgres/defaultSnapshot.js +4 -1
  113. package/dist/postgres/defaultSnapshot.js.map +1 -1
  114. package/dist/postgres/init.d.ts.map +1 -1
  115. package/dist/postgres/init.js +12 -3
  116. package/dist/postgres/init.js.map +1 -1
  117. package/dist/postgres/schema/build.d.ts +12 -2
  118. package/dist/postgres/schema/build.d.ts.map +1 -1
  119. package/dist/postgres/schema/build.js +45 -10
  120. package/dist/postgres/schema/build.js.map +1 -1
  121. package/dist/postgres/schema/createIndex.d.ts +2 -3
  122. package/dist/postgres/schema/createIndex.d.ts.map +1 -1
  123. package/dist/postgres/schema/createIndex.js +5 -3
  124. package/dist/postgres/schema/createIndex.js.map +1 -1
  125. package/dist/postgres/schema/geometryColumn.d.ts +12 -0
  126. package/dist/postgres/schema/geometryColumn.d.ts.map +1 -0
  127. package/dist/postgres/schema/geometryColumn.js +18 -0
  128. package/dist/postgres/schema/geometryColumn.js.map +1 -0
  129. package/dist/postgres/schema/traverseFields.d.ts +9 -2
  130. package/dist/postgres/schema/traverseFields.d.ts.map +1 -1
  131. package/dist/postgres/schema/traverseFields.js +393 -265
  132. package/dist/postgres/schema/traverseFields.js.map +1 -1
  133. package/dist/postgres/schema/withDefault.d.ts.map +1 -1
  134. package/dist/postgres/schema/withDefault.js +6 -1
  135. package/dist/postgres/schema/withDefault.js.map +1 -1
  136. package/dist/postgres/types.d.ts +37 -7
  137. package/dist/postgres/types.d.ts.map +1 -1
  138. package/dist/postgres/types.js.map +1 -1
  139. package/dist/queries/addJoinTable.d.ts +11 -0
  140. package/dist/queries/addJoinTable.d.ts.map +1 -0
  141. package/dist/queries/addJoinTable.js +13 -0
  142. package/dist/queries/addJoinTable.js.map +1 -0
  143. package/dist/queries/buildAndOrConditions.d.ts +1 -1
  144. package/dist/queries/buildAndOrConditions.d.ts.map +1 -1
  145. package/dist/queries/buildAndOrConditions.js +2 -4
  146. package/dist/queries/buildAndOrConditions.js.map +1 -1
  147. package/dist/queries/buildOrderBy.d.ts +18 -0
  148. package/dist/queries/buildOrderBy.d.ts.map +1 -0
  149. package/dist/queries/buildOrderBy.js +56 -0
  150. package/dist/queries/buildOrderBy.js.map +1 -0
  151. package/dist/queries/buildQuery.d.ts +8 -7
  152. package/dist/queries/buildQuery.d.ts.map +1 -1
  153. package/dist/queries/buildQuery.js +12 -47
  154. package/dist/queries/buildQuery.js.map +1 -1
  155. package/dist/queries/getTableColumnFromPath.d.ts +6 -2
  156. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  157. package/dist/queries/getTableColumnFromPath.js +270 -223
  158. package/dist/queries/getTableColumnFromPath.js.map +1 -1
  159. package/dist/queries/operatorMap.d.ts.map +1 -1
  160. package/dist/queries/operatorMap.js +0 -4
  161. package/dist/queries/operatorMap.js.map +1 -1
  162. package/dist/queries/parseParams.d.ts +1 -1
  163. package/dist/queries/parseParams.d.ts.map +1 -1
  164. package/dist/queries/parseParams.js +85 -6
  165. package/dist/queries/parseParams.js.map +1 -1
  166. package/dist/queries/sanitizeQueryValue.d.ts +12 -1
  167. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
  168. package/dist/queries/sanitizeQueryValue.js +89 -25
  169. package/dist/queries/sanitizeQueryValue.js.map +1 -1
  170. package/dist/queries/selectDistinct.d.ts +3 -4
  171. package/dist/queries/selectDistinct.d.ts.map +1 -1
  172. package/dist/queries/selectDistinct.js.map +1 -1
  173. package/dist/queryDrafts.d.ts.map +1 -1
  174. package/dist/queryDrafts.js +6 -6
  175. package/dist/queryDrafts.js.map +1 -1
  176. package/dist/transactions/beginTransaction.d.ts.map +1 -1
  177. package/dist/transactions/beginTransaction.js +5 -1
  178. package/dist/transactions/beginTransaction.js.map +1 -1
  179. package/dist/transactions/commitTransaction.d.ts.map +1 -1
  180. package/dist/transactions/commitTransaction.js +3 -1
  181. package/dist/transactions/commitTransaction.js.map +1 -1
  182. package/dist/transform/read/hasManyNumber.d.ts +2 -1
  183. package/dist/transform/read/hasManyNumber.d.ts.map +1 -1
  184. package/dist/transform/read/hasManyNumber.js +12 -2
  185. package/dist/transform/read/hasManyNumber.js.map +1 -1
  186. package/dist/transform/read/hasManyText.d.ts +2 -1
  187. package/dist/transform/read/hasManyText.d.ts.map +1 -1
  188. package/dist/transform/read/hasManyText.js +12 -2
  189. package/dist/transform/read/hasManyText.js.map +1 -1
  190. package/dist/transform/read/index.d.ts +3 -2
  191. package/dist/transform/read/index.d.ts.map +1 -1
  192. package/dist/transform/read/index.js +3 -2
  193. package/dist/transform/read/index.js.map +1 -1
  194. package/dist/transform/read/relationship.d.ts +2 -1
  195. package/dist/transform/read/relationship.d.ts.map +1 -1
  196. package/dist/transform/read/relationship.js +15 -6
  197. package/dist/transform/read/relationship.js.map +1 -1
  198. package/dist/transform/read/traverseFields.d.ts +10 -2
  199. package/dist/transform/read/traverseFields.d.ts.map +1 -1
  200. package/dist/transform/read/traverseFields.js +185 -71
  201. package/dist/transform/read/traverseFields.js.map +1 -1
  202. package/dist/transform/write/array.d.ts +6 -1
  203. package/dist/transform/write/array.d.ts.map +1 -1
  204. package/dist/transform/write/array.js +7 -3
  205. package/dist/transform/write/array.js.map +1 -1
  206. package/dist/transform/write/blocks.d.ts +8 -3
  207. package/dist/transform/write/blocks.d.ts.map +1 -1
  208. package/dist/transform/write/blocks.js +19 -7
  209. package/dist/transform/write/blocks.js.map +1 -1
  210. package/dist/transform/write/index.d.ts.map +1 -1
  211. package/dist/transform/write/index.js +1 -1
  212. package/dist/transform/write/index.js.map +1 -1
  213. package/dist/transform/write/relationships.d.ts.map +1 -1
  214. package/dist/transform/write/relationships.js +6 -2
  215. package/dist/transform/write/relationships.js.map +1 -1
  216. package/dist/transform/write/selects.d.ts.map +1 -1
  217. package/dist/transform/write/selects.js +1 -1
  218. package/dist/transform/write/selects.js.map +1 -1
  219. package/dist/transform/write/traverseFields.d.ts +6 -1
  220. package/dist/transform/write/traverseFields.d.ts.map +1 -1
  221. package/dist/transform/write/traverseFields.js +62 -19
  222. package/dist/transform/write/traverseFields.js.map +1 -1
  223. package/dist/types.d.ts +6 -4
  224. package/dist/types.d.ts.map +1 -1
  225. package/dist/types.js.map +1 -1
  226. package/dist/update.d.ts.map +1 -1
  227. package/dist/update.js +4 -2
  228. package/dist/update.js.map +1 -1
  229. package/dist/updateGlobal.d.ts +1 -1
  230. package/dist/updateGlobal.d.ts.map +1 -1
  231. package/dist/updateGlobal.js +2 -1
  232. package/dist/updateGlobal.js.map +1 -1
  233. package/dist/updateGlobalVersion.d.ts +1 -1
  234. package/dist/updateGlobalVersion.d.ts.map +1 -1
  235. package/dist/updateGlobalVersion.js +4 -3
  236. package/dist/updateGlobalVersion.js.map +1 -1
  237. package/dist/updateVersion.d.ts +1 -1
  238. package/dist/updateVersion.d.ts.map +1 -1
  239. package/dist/updateVersion.js +4 -3
  240. package/dist/updateVersion.js.map +1 -1
  241. package/dist/upsertRow/deleteExistingRowsByPath.d.ts.map +1 -1
  242. package/dist/upsertRow/deleteExistingRowsByPath.js +6 -2
  243. package/dist/upsertRow/deleteExistingRowsByPath.js.map +1 -1
  244. package/dist/upsertRow/index.d.ts +1 -1
  245. package/dist/upsertRow/index.d.ts.map +1 -1
  246. package/dist/upsertRow/index.js +51 -13
  247. package/dist/upsertRow/index.js.map +1 -1
  248. package/dist/upsertRow/insertArrays.d.ts.map +1 -1
  249. package/dist/upsertRow/insertArrays.js +5 -2
  250. package/dist/upsertRow/insertArrays.js.map +1 -1
  251. package/dist/upsertRow/types.d.ts +10 -5
  252. package/dist/upsertRow/types.d.ts.map +1 -1
  253. package/dist/upsertRow/types.js.map +1 -1
  254. package/dist/utilities/buildIndexName.d.ts +7 -0
  255. package/dist/utilities/buildIndexName.d.ts.map +1 -0
  256. package/dist/utilities/buildIndexName.js +14 -0
  257. package/dist/utilities/buildIndexName.js.map +1 -0
  258. package/dist/utilities/createBlocksMap.d.ts.map +1 -1
  259. package/dist/utilities/createBlocksMap.js +4 -2
  260. package/dist/utilities/createBlocksMap.js.map +1 -1
  261. package/dist/utilities/createRelationshipMap.d.ts.map +1 -1
  262. package/dist/utilities/createRelationshipMap.js +3 -1
  263. package/dist/utilities/createRelationshipMap.js.map +1 -1
  264. package/dist/utilities/executeSchemaHooks.d.ts +24 -0
  265. package/dist/utilities/executeSchemaHooks.d.ts.map +1 -0
  266. package/dist/utilities/executeSchemaHooks.js +21 -0
  267. package/dist/utilities/executeSchemaHooks.js.map +1 -0
  268. package/dist/utilities/extendDrizzleTable.d.ts +19 -0
  269. package/dist/utilities/extendDrizzleTable.d.ts.map +1 -0
  270. package/dist/utilities/extendDrizzleTable.js +38 -0
  271. package/dist/utilities/extendDrizzleTable.js.map +1 -0
  272. package/dist/utilities/getCollectionIdType.d.ts +7 -0
  273. package/dist/utilities/getCollectionIdType.d.ts.map +1 -0
  274. package/dist/utilities/getCollectionIdType.js +11 -0
  275. package/dist/utilities/getCollectionIdType.js.map +1 -0
  276. package/dist/utilities/getNameFromDrizzleTable.d.ts +3 -0
  277. package/dist/utilities/getNameFromDrizzleTable.d.ts.map +1 -0
  278. package/dist/utilities/getNameFromDrizzleTable.js +6 -0
  279. package/dist/utilities/getNameFromDrizzleTable.js.map +1 -0
  280. package/dist/utilities/hasLocalesTable.d.ts.map +1 -1
  281. package/dist/utilities/hasLocalesTable.js +12 -4
  282. package/dist/utilities/hasLocalesTable.js.map +1 -1
  283. package/dist/utilities/isPolymorphicRelationship.d.ts +6 -0
  284. package/dist/utilities/isPolymorphicRelationship.d.ts.map +1 -0
  285. package/dist/utilities/isPolymorphicRelationship.js +5 -0
  286. package/dist/utilities/isPolymorphicRelationship.js.map +1 -0
  287. package/dist/utilities/pushDevSchema.d.ts.map +1 -1
  288. package/dist/utilities/pushDevSchema.js +5 -0
  289. package/dist/utilities/pushDevSchema.js.map +1 -1
  290. package/license.md +22 -0
  291. package/package.json +17 -8
@@ -1,7 +1,13 @@
1
- import { fieldAffectsData, tabHasName } from 'payload/shared';
1
+ import { and, eq, sql } from 'drizzle-orm';
2
+ import { fieldAffectsData, fieldIsVirtual, tabHasName } from 'payload/shared';
2
3
  import toSnakeCase from 'to-snake-case';
3
- export const traverseFields = ({ _locales, adapter, currentArgs, currentTableName, depth, fields, path, topLevelArgs, topLevelTableName })=>{
4
+ import buildQuery from '../queries/buildQuery.js';
5
+ import { chainMethods } from './chainMethods.js';
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 })=>{
4
7
  fields.forEach((field)=>{
8
+ if (fieldIsVirtual(field)) {
9
+ return;
10
+ }
5
11
  // handle simple relationship
6
12
  if (depth > 0 && (field.type === 'upload' || field.type === 'relationship') && !field.hasMany && typeof field.relationTo === 'string') {
7
13
  if (field.localized) {
@@ -10,7 +16,7 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
10
16
  currentArgs.with[`${path}${field.name}`] = true;
11
17
  }
12
18
  }
13
- if (field.type === 'collapsible' || field.type === 'row') {
19
+ if (field.type === 'collapsible' || field.type === 'row' || field.type === 'tab' && !tabHasName(field)) {
14
20
  traverseFields({
15
21
  _locales,
16
22
  adapter,
@@ -18,26 +24,40 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
18
24
  currentTableName,
19
25
  depth,
20
26
  fields: field.fields,
27
+ joinQuery,
28
+ joins,
21
29
  path,
30
+ select,
31
+ selectMode,
32
+ tablePath,
22
33
  topLevelArgs,
23
- topLevelTableName
34
+ topLevelTableName,
35
+ withTabledFields
24
36
  });
25
37
  return;
26
38
  }
27
39
  if (field.type === 'tabs') {
28
- field.tabs.forEach((tab)=>{
29
- const tabPath = tabHasName(tab) ? `${path}${tab.name}_` : path;
30
- traverseFields({
31
- _locales,
32
- adapter,
33
- currentArgs,
34
- currentTableName,
35
- depth,
36
- fields: tab.fields,
37
- path: tabPath,
38
- topLevelArgs,
39
- topLevelTableName
40
- });
40
+ traverseFields({
41
+ _locales,
42
+ adapter,
43
+ currentArgs,
44
+ currentTableName,
45
+ depth,
46
+ fields: field.tabs.map((tab)=>({
47
+ ...tab,
48
+ type: 'tab'
49
+ })),
50
+ joinQuery,
51
+ joins,
52
+ path,
53
+ select,
54
+ selectAllOnCurrentLevel,
55
+ selectMode,
56
+ tablePath,
57
+ topLevelArgs,
58
+ topLevelTableName,
59
+ versions,
60
+ withTabledFields
41
61
  });
42
62
  return;
43
63
  }
@@ -45,8 +65,17 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
45
65
  switch(field.type){
46
66
  case 'array':
47
67
  {
68
+ const arraySelect = selectAllOnCurrentLevel ? true : select?.[field.name];
69
+ if (select) {
70
+ if (selectMode === 'include' && typeof arraySelect === 'undefined' || selectMode === 'exclude' && arraySelect === false) {
71
+ break;
72
+ }
73
+ }
48
74
  const withArray = {
49
- columns: {
75
+ columns: typeof arraySelect === 'object' ? {
76
+ id: true,
77
+ _order: true
78
+ } : {
50
79
  _parentID: false
51
80
  },
52
81
  orderBy: ({ _order }, { asc })=>[
@@ -54,11 +83,21 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
54
83
  ],
55
84
  with: {}
56
85
  };
57
- const arrayTableName = adapter.tableNameMap.get(`${currentTableName}_${path}${toSnakeCase(field.name)}`);
86
+ const arrayTableName = adapter.tableNameMap.get(`${currentTableName}_${tablePath}${toSnakeCase(field.name)}`);
87
+ if (typeof arraySelect === 'object') {
88
+ if (adapter.tables[arrayTableName]._locale) {
89
+ withArray.columns._locale = true;
90
+ }
91
+ if (adapter.tables[arrayTableName]._uuid) {
92
+ withArray.columns._uuid = true;
93
+ }
94
+ }
58
95
  const arrayTableNameWithLocales = `${arrayTableName}${adapter.localesSuffix}`;
59
96
  if (adapter.tables[arrayTableNameWithLocales]) {
60
97
  withArray.with._locales = {
61
- columns: {
98
+ columns: typeof arraySelect === 'object' ? {
99
+ _locale: true
100
+ } : {
62
101
  id: false,
63
102
  _parentID: false
64
103
  },
@@ -73,15 +112,293 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
73
112
  currentTableName: arrayTableName,
74
113
  depth,
75
114
  fields: field.fields,
115
+ joinQuery,
76
116
  path: '',
117
+ select: typeof arraySelect === 'object' ? arraySelect : undefined,
118
+ selectMode,
119
+ tablePath: '',
120
+ topLevelArgs,
121
+ topLevelTableName,
122
+ withinLocalizedField: withinLocalizedField || field.localized,
123
+ withTabledFields
124
+ });
125
+ if (typeof arraySelect === 'object' && withArray.with._locales && Object.keys(withArray.with._locales).length === 1) {
126
+ delete withArray.with._locales;
127
+ }
128
+ break;
129
+ }
130
+ case 'blocks':
131
+ {
132
+ const blocksSelect = selectAllOnCurrentLevel ? true : select?.[field.name];
133
+ if (select) {
134
+ if (selectMode === 'include' && !blocksSelect || selectMode === 'exclude' && blocksSelect === false) {
135
+ break;
136
+ }
137
+ }
138
+ field.blocks.forEach((block)=>{
139
+ const blockKey = `_blocks_${block.slug}`;
140
+ let blockSelect;
141
+ let blockSelectMode = selectMode;
142
+ if (selectMode === 'include' && blocksSelect === true) {
143
+ blockSelect = true;
144
+ }
145
+ if (typeof blocksSelect === 'object') {
146
+ if (typeof blocksSelect[block.slug] === 'object') {
147
+ blockSelect = blocksSelect[block.slug];
148
+ } else if (selectMode === 'include' && typeof blocksSelect[block.slug] === 'undefined' || selectMode === 'exclude' && blocksSelect[block.slug] === false) {
149
+ blockSelect = {};
150
+ blockSelectMode = 'include';
151
+ } else if (selectMode === 'include' && blocksSelect[block.slug] === true) {
152
+ blockSelect = true;
153
+ }
154
+ }
155
+ if (!topLevelArgs[blockKey]) {
156
+ const withBlock = {
157
+ columns: typeof blockSelect === 'object' ? {
158
+ id: true,
159
+ _order: true,
160
+ _path: true
161
+ } : {
162
+ _parentID: false
163
+ },
164
+ orderBy: ({ _order }, { asc })=>[
165
+ asc(_order)
166
+ ],
167
+ with: {}
168
+ };
169
+ const tableName = adapter.tableNameMap.get(`${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`);
170
+ if (typeof blockSelect === 'object') {
171
+ if (adapter.tables[tableName]._locale) {
172
+ withBlock.columns._locale = true;
173
+ }
174
+ if (adapter.tables[tableName]._uuid) {
175
+ withBlock.columns._uuid = true;
176
+ }
177
+ }
178
+ if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {
179
+ withBlock.with._locales = {
180
+ with: {}
181
+ };
182
+ if (typeof blockSelect === 'object') {
183
+ withBlock.with._locales.columns = {
184
+ _locale: true
185
+ };
186
+ }
187
+ }
188
+ topLevelArgs.with[blockKey] = withBlock;
189
+ traverseFields({
190
+ _locales: withBlock.with._locales,
191
+ adapter,
192
+ currentArgs: withBlock,
193
+ currentTableName: tableName,
194
+ depth,
195
+ fields: block.fields,
196
+ joinQuery,
197
+ path: '',
198
+ select: typeof blockSelect === 'object' ? blockSelect : undefined,
199
+ selectMode: blockSelectMode,
200
+ tablePath: '',
201
+ topLevelArgs,
202
+ topLevelTableName,
203
+ withinLocalizedField: withinLocalizedField || field.localized,
204
+ withTabledFields
205
+ });
206
+ if (typeof blockSelect === 'object' && withBlock.with._locales && Object.keys(withBlock.with._locales.columns).length === 1) {
207
+ delete withBlock.with._locales;
208
+ }
209
+ }
210
+ });
211
+ break;
212
+ }
213
+ case 'group':
214
+ case 'tab':
215
+ {
216
+ const fieldSelect = select?.[field.name];
217
+ if (fieldSelect === false) {
218
+ break;
219
+ }
220
+ traverseFields({
221
+ _locales,
222
+ adapter,
223
+ currentArgs,
224
+ currentTableName,
225
+ depth,
226
+ fields: field.fields,
227
+ joinQuery,
228
+ joins,
229
+ path: `${path}${field.name}_`,
230
+ select: typeof fieldSelect === 'object' ? fieldSelect : undefined,
231
+ selectAllOnCurrentLevel: selectAllOnCurrentLevel || fieldSelect === true || selectMode === 'exclude' && typeof fieldSelect === 'undefined',
232
+ selectMode,
233
+ tablePath: `${tablePath}${toSnakeCase(field.name)}_`,
77
234
  topLevelArgs,
78
- topLevelTableName
235
+ topLevelTableName,
236
+ versions,
237
+ withinLocalizedField: withinLocalizedField || field.localized,
238
+ withTabledFields
79
239
  });
80
240
  break;
81
241
  }
242
+ case 'join':
243
+ {
244
+ // when `joinsQuery` is false, do not join
245
+ if (joinQuery === false) {
246
+ break;
247
+ }
248
+ if (select && selectMode === 'include' && !select[field.name] || selectMode === 'exclude' && select[field.name] === false) {
249
+ break;
250
+ }
251
+ const joinSchemaPath = `${path.replaceAll('_', '.')}${field.name}`;
252
+ if (joinQuery[joinSchemaPath] === false) {
253
+ break;
254
+ }
255
+ const { limit: limitArg = field.defaultLimit ?? 10, sort = field.defaultSort, where } = joinQuery[joinSchemaPath] || {};
256
+ let limit = limitArg;
257
+ if (limit !== 0) {
258
+ // get an additional document and slice it later to determine if there is a next page
259
+ limit += 1;
260
+ }
261
+ const fields = adapter.payload.collections[field.collection].config.fields;
262
+ const joinCollectionTableName = adapter.tableNameMap.get(toSnakeCase(field.collection));
263
+ const joins = [];
264
+ const buildQueryResult = buildQuery({
265
+ adapter,
266
+ fields,
267
+ joins,
268
+ locale,
269
+ sort,
270
+ tableName: joinCollectionTableName,
271
+ where
272
+ });
273
+ let subQueryWhere = buildQueryResult.where;
274
+ const orderBy = buildQueryResult.orderBy;
275
+ let joinLocalesCollectionTableName;
276
+ const currentIDColumn = versions ? adapter.tables[currentTableName].parent : adapter.tables[currentTableName].id;
277
+ // Handle hasMany _rels table
278
+ if (field.hasMany) {
279
+ const joinRelsCollectionTableName = `${joinCollectionTableName}${adapter.relationshipsSuffix}`;
280
+ if (field.localized) {
281
+ joinLocalesCollectionTableName = joinRelsCollectionTableName;
282
+ }
283
+ let columnReferenceToCurrentID;
284
+ if (versions) {
285
+ columnReferenceToCurrentID = `${topLevelTableName.replace('_', '').replace(new RegExp(`${adapter.versionsSuffix}$`), '')}_id`;
286
+ } else {
287
+ columnReferenceToCurrentID = `${topLevelTableName}_id`;
288
+ }
289
+ joins.push({
290
+ type: 'innerJoin',
291
+ condition: and(eq(adapter.tables[joinRelsCollectionTableName].parent, adapter.tables[joinCollectionTableName].id), eq(sql.raw(`"${joinRelsCollectionTableName}"."${columnReferenceToCurrentID}"`), currentIDColumn), eq(adapter.tables[joinRelsCollectionTableName].path, field.on)),
292
+ table: adapter.tables[joinRelsCollectionTableName]
293
+ });
294
+ } else {
295
+ // Handle localized without hasMany
296
+ const foreignColumn = field.on.replaceAll('.', '_');
297
+ if (field.localized) {
298
+ joinLocalesCollectionTableName = `${joinCollectionTableName}${adapter.localesSuffix}`;
299
+ joins.push({
300
+ type: 'innerJoin',
301
+ condition: and(eq(adapter.tables[joinLocalesCollectionTableName]._parentID, adapter.tables[joinCollectionTableName].id), eq(adapter.tables[joinLocalesCollectionTableName][foreignColumn], currentIDColumn)),
302
+ table: adapter.tables[joinLocalesCollectionTableName]
303
+ });
304
+ // Handle without localized and without hasMany, just a condition append to where. With localized the inner join handles eq.
305
+ } else {
306
+ const constraint = eq(adapter.tables[joinCollectionTableName][foreignColumn], currentIDColumn);
307
+ if (subQueryWhere) {
308
+ subQueryWhere = and(subQueryWhere, constraint);
309
+ } else {
310
+ subQueryWhere = constraint;
311
+ }
312
+ }
313
+ }
314
+ const chainedMethods = [];
315
+ joins.forEach(({ type, condition, table })=>{
316
+ chainedMethods.push({
317
+ args: [
318
+ table,
319
+ condition
320
+ ],
321
+ method: type ?? 'leftJoin'
322
+ });
323
+ });
324
+ if (limit !== 0) {
325
+ chainedMethods.push({
326
+ args: [
327
+ limit
328
+ ],
329
+ method: 'limit'
330
+ });
331
+ }
332
+ const db = adapter.drizzle;
333
+ const subQuery = chainMethods({
334
+ methods: chainedMethods,
335
+ query: db.select({
336
+ id: adapter.tables[joinCollectionTableName].id,
337
+ ...joinLocalesCollectionTableName && {
338
+ locale: adapter.tables[joinLocalesCollectionTableName].locale || adapter.tables[joinLocalesCollectionTableName]._locale
339
+ }
340
+ }).from(adapter.tables[joinCollectionTableName]).where(subQueryWhere).orderBy(()=>orderBy.map(({ column, order })=>order(column)))
341
+ });
342
+ const columnName = `${path.replaceAll('.', '_')}${field.name}`;
343
+ const jsonObjectSelect = field.localized ? sql.raw(`'_parentID', "id", '_locale', "${adapter.tables[joinLocalesCollectionTableName].locale ? 'locale' : '_locale'}"`) : sql.raw(`'id', "id"`);
344
+ if (adapter.name === 'sqlite') {
345
+ currentArgs.extras[columnName] = sql`
346
+ COALESCE((
347
+ SELECT json_group_array(json_object(${jsonObjectSelect}))
348
+ FROM (
349
+ ${subQuery}
350
+ ) AS ${sql.raw(`${columnName}_sub`)}
351
+ ), '[]')
352
+ `.as(columnName);
353
+ } else {
354
+ currentArgs.extras[columnName] = sql`
355
+ COALESCE((
356
+ SELECT json_agg(json_build_object(${jsonObjectSelect}))
357
+ FROM (
358
+ ${subQuery}
359
+ ) AS ${sql.raw(`${columnName}_sub`)}
360
+ ), '[]'::json)
361
+ `.as(columnName);
362
+ }
363
+ break;
364
+ }
365
+ case 'point':
366
+ {
367
+ if (adapter.name === 'sqlite') {
368
+ break;
369
+ }
370
+ const args = field.localized ? _locales : currentArgs;
371
+ if (!args.columns) {
372
+ args.columns = {};
373
+ }
374
+ if (!args.extras) {
375
+ args.extras = {};
376
+ }
377
+ const name = `${path}${field.name}`;
378
+ // Drizzle handles that poorly. See https://github.com/drizzle-team/drizzle-orm/issues/2526
379
+ // Additionally, this way we format the column value straight in the database using ST_AsGeoJSON
380
+ args.columns[name] = false;
381
+ let shouldSelect = false;
382
+ if (select || selectAllOnCurrentLevel) {
383
+ if (selectAllOnCurrentLevel || selectMode === 'include' && select[field.name] === true || selectMode === 'exclude' && typeof select[field.name] === 'undefined') {
384
+ shouldSelect = true;
385
+ }
386
+ } else {
387
+ shouldSelect = true;
388
+ }
389
+ if (shouldSelect) {
390
+ args.extras[name] = sql.raw(`ST_AsGeoJSON(${toSnakeCase(name)})::jsonb`).as(name);
391
+ }
392
+ break;
393
+ }
82
394
  case 'select':
83
395
  {
84
396
  if (field.hasMany) {
397
+ if (select) {
398
+ if (selectMode === 'include' && !select[field.name] || selectMode === 'exclude' && select[field.name] === false) {
399
+ break;
400
+ }
401
+ }
85
402
  const withSelect = {
86
403
  columns: {
87
404
  id: false,
@@ -96,55 +413,28 @@ export const traverseFields = ({ _locales, adapter, currentArgs, currentTableNam
96
413
  }
97
414
  break;
98
415
  }
99
- case 'blocks':
100
- field.blocks.forEach((block)=>{
101
- const blockKey = `_blocks_${block.slug}`;
102
- if (!topLevelArgs[blockKey]) {
103
- const withBlock = {
104
- columns: {
105
- _parentID: false
106
- },
107
- orderBy: ({ _order }, { asc })=>[
108
- asc(_order)
109
- ],
110
- with: {}
111
- };
112
- const tableName = adapter.tableNameMap.get(`${topLevelTableName}_blocks_${toSnakeCase(block.slug)}`);
113
- if (adapter.tables[`${tableName}${adapter.localesSuffix}`]) {
114
- withBlock.with._locales = {
115
- with: {}
116
- };
117
- }
118
- topLevelArgs.with[blockKey] = withBlock;
119
- traverseFields({
120
- _locales: withBlock.with._locales,
121
- adapter,
122
- currentArgs: withBlock,
123
- currentTableName: tableName,
124
- depth,
125
- fields: block.fields,
126
- path: '',
127
- topLevelArgs,
128
- topLevelTableName
129
- });
130
- }
131
- });
132
- break;
133
- case 'group':
134
- traverseFields({
135
- _locales,
136
- adapter,
137
- currentArgs,
138
- currentTableName,
139
- depth,
140
- fields: field.fields,
141
- path: `${path}${field.name}_`,
142
- topLevelArgs,
143
- topLevelTableName
144
- });
145
- break;
146
416
  default:
147
417
  {
418
+ if (!select && !selectAllOnCurrentLevel) {
419
+ break;
420
+ }
421
+ if (selectAllOnCurrentLevel || selectMode === 'include' && select[field.name] === true || selectMode === 'exclude' && typeof select[field.name] === 'undefined') {
422
+ const fieldPath = `${path}${field.name}`;
423
+ if ((field.localized || withinLocalizedField) && _locales) {
424
+ _locales.columns[fieldPath] = true;
425
+ } else if (adapter.tables[currentTableName]?.[fieldPath]) {
426
+ currentArgs.columns[fieldPath] = true;
427
+ }
428
+ if (!withTabledFields.rels && field.type === 'relationship' && (field.hasMany || Array.isArray(field.relationTo))) {
429
+ withTabledFields.rels = true;
430
+ }
431
+ if (!withTabledFields.numbers && field.type === 'number' && field.hasMany) {
432
+ withTabledFields.numbers = true;
433
+ }
434
+ if (!withTabledFields.texts && field.type === 'text' && field.hasMany) {
435
+ withTabledFields.texts = true;
436
+ }
437
+ }
148
438
  break;
149
439
  }
150
440
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { Field } from 'payload'\n\nimport { fieldAffectsData, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter } from '../types.js'\nimport type { Result } from './buildFindManyArgs.js'\n\ntype TraverseFieldArgs = {\n _locales: Result\n adapter: DrizzleAdapter\n currentArgs: Result\n currentTableName: string\n depth?: number\n fields: Field[]\n path: string\n topLevelArgs: Record<string, unknown>\n topLevelTableName: string\n}\n\nexport const traverseFields = ({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields,\n path,\n topLevelArgs,\n topLevelTableName,\n}: TraverseFieldArgs) => {\n fields.forEach((field) => {\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 path,\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\n traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: tab.fields,\n path: tabPath,\n topLevelArgs,\n topLevelTableName,\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}_${path}${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 path: '',\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 path: '',\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 path: `${path}${field.name}_`,\n topLevelArgs,\n topLevelTableName,\n })\n\n break\n\n default: {\n break\n }\n }\n }\n })\n\n return topLevelArgs\n}\n"],"names":["fieldAffectsData","tabHasName","toSnakeCase","traverseFields","_locales","adapter","currentArgs","currentTableName","depth","fields","path","topLevelArgs","topLevelTableName","forEach","field","type","hasMany","relationTo","localized","with","name","tabs","tab","tabPath","withArray","columns","_parentID","orderBy","_order","asc","arrayTableName","tableNameMap","get","arrayTableNameWithLocales","localesSuffix","tables","id","withSelect","order","parent","blocks","block","blockKey","slug","withBlock","tableName"],"mappings":"AAEA,SAASA,gBAAgB,EAAEC,UAAU,QAAQ,iBAAgB;AAC7D,OAAOC,iBAAiB,gBAAe;AAiBvC,OAAO,MAAMC,iBAAiB,CAAC,EAC7BC,QAAQ,EACRC,OAAO,EACPC,WAAW,EACXC,gBAAgB,EAChBC,KAAK,EACLC,MAAM,EACNC,IAAI,EACJC,YAAY,EACZC,iBAAiB,EACC;IAClBH,OAAOI,OAAO,CAAC,CAACC;QACd,6BAA6B;QAC7B,IACEN,QAAQ,KACPM,CAAAA,MAAMC,IAAI,KAAK,YAAYD,MAAMC,IAAI,KAAK,cAAa,KACxD,CAACD,MAAME,OAAO,IACd,OAAOF,MAAMG,UAAU,KAAK,UAC5B;YACA,IAAIH,MAAMI,SAAS,EAAE;gBACnBd,SAASe,IAAI,CAAC,CAAC,EAAET,KAAK,EAAEI,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAG;YAC1C,OAAO;gBACLd,YAAYa,IAAI,CAAC,CAAC,EAAET,KAAK,EAAEI,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAG;YAC7C;QACF;QAEA,IAAIN,MAAMC,IAAI,KAAK,iBAAiBD,MAAMC,IAAI,KAAK,OAAO;YACxDZ,eAAe;gBACbC;gBACAC;gBACAC;gBACAC;gBACAC;gBACAC,QAAQK,MAAML,MAAM;gBACpBC;gBACAC;gBACAC;YACF;YAEA;QACF;QAEA,IAAIE,MAAMC,IAAI,KAAK,QAAQ;YACzBD,MAAMO,IAAI,CAACR,OAAO,CAAC,CAACS;gBAClB,MAAMC,UAAUtB,WAAWqB,OAAO,CAAC,EAAEZ,KAAK,EAAEY,IAAIF,IAAI,CAAC,CAAC,CAAC,GAAGV;gBAE1DP,eAAe;oBACbC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC,QAAQa,IAAIb,MAAM;oBAClBC,MAAMa;oBACNZ;oBACAC;gBACF;YACF;YAEA;QACF;QAEA,IAAIZ,iBAAiBc,QAAQ;YAC3B,OAAQA,MAAMC,IAAI;gBAChB,KAAK;oBAAS;wBACZ,MAAMS,YAAoB;4BACxBC,SAAS;gCACPC,WAAW;4BACb;4BACAC,SAAS,CAAC,EAAEC,MAAM,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAK;oCAACA,IAAID;iCAAQ;4BAC/CT,MAAM,CAAC;wBACT;wBAEA,MAAMW,iBAAiBzB,QAAQ0B,YAAY,CAACC,GAAG,CAC7C,CAAC,EAAEzB,iBAAiB,CAAC,EAAEG,KAAK,EAAER,YAAYY,MAAMM,IAAI,EAAE,CAAC;wBAGzD,MAAMa,4BAA4B,CAAC,EAAEH,eAAe,EAAEzB,QAAQ6B,aAAa,CAAC,CAAC;wBAE7E,IAAI7B,QAAQ8B,MAAM,CAACF,0BAA0B,EAAE;4BAC7CT,UAAUL,IAAI,CAACf,QAAQ,GAAG;gCACxBqB,SAAS;oCACPW,IAAI;oCACJV,WAAW;gCACb;gCACAP,MAAM,CAAC;4BACT;wBACF;wBACAb,YAAYa,IAAI,CAAC,CAAC,EAAET,KAAK,EAAEI,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAGI;wBAE3CrB,eAAe;4BACbC,UAAUoB,UAAUL,IAAI,CAACf,QAAQ;4BACjCC;4BACAC,aAAakB;4BACbjB,kBAAkBuB;4BAClBtB;4BACAC,QAAQK,MAAML,MAAM;4BACpBC,MAAM;4BACNC;4BACAC;wBACF;wBAEA;oBACF;gBAEA,KAAK;oBAAU;wBACb,IAAIE,MAAME,OAAO,EAAE;4BACjB,MAAMqB,aAAqB;gCACzBZ,SAAS;oCACPW,IAAI;oCACJE,OAAO;oCACPC,QAAQ;gCACV;gCACAZ,SAAS,CAAC,EAAEW,KAAK,EAAE,EAAE,EAAET,GAAG,EAAE,GAAK;wCAACA,IAAIS;qCAAO;4BAC/C;4BAEAhC,YAAYa,IAAI,CAAC,CAAC,EAAET,KAAK,EAAEI,MAAMM,IAAI,CAAC,CAAC,CAAC,GAAGiB;wBAC7C;wBAEA;oBACF;gBAEA,KAAK;oBACHvB,MAAM0B,MAAM,CAAC3B,OAAO,CAAC,CAAC4B;wBACpB,MAAMC,WAAW,CAAC,QAAQ,EAAED,MAAME,IAAI,CAAC,CAAC;wBAExC,IAAI,CAAChC,YAAY,CAAC+B,SAAS,EAAE;4BAC3B,MAAME,YAAoB;gCACxBnB,SAAS;oCACPC,WAAW;gCACb;gCACAC,SAAS,CAAC,EAAEC,MAAM,EAAE,EAAE,EAAEC,GAAG,EAAE,GAAK;wCAACA,IAAID;qCAAQ;gCAC/CT,MAAM,CAAC;4BACT;4BAEA,MAAM0B,YAAYxC,QAAQ0B,YAAY,CAACC,GAAG,CACxC,CAAC,EAAEpB,kBAAkB,QAAQ,EAAEV,YAAYuC,MAAME,IAAI,EAAE,CAAC;4BAG1D,IAAItC,QAAQ8B,MAAM,CAAC,CAAC,EAAEU,UAAU,EAAExC,QAAQ6B,aAAa,CAAC,CAAC,CAAC,EAAE;gCAC1DU,UAAUzB,IAAI,CAACf,QAAQ,GAAG;oCACxBe,MAAM,CAAC;gCACT;4BACF;4BACAR,aAAaQ,IAAI,CAACuB,SAAS,GAAGE;4BAE9BzC,eAAe;gCACbC,UAAUwC,UAAUzB,IAAI,CAACf,QAAQ;gCACjCC;gCACAC,aAAasC;gCACbrC,kBAAkBsC;gCAClBrC;gCACAC,QAAQgC,MAAMhC,MAAM;gCACpBC,MAAM;gCACNC;gCACAC;4BACF;wBACF;oBACF;oBAEA;gBAEF,KAAK;oBACHT,eAAe;wBACbC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,QAAQK,MAAML,MAAM;wBACpBC,MAAM,CAAC,EAAEA,KAAK,EAAEI,MAAMM,IAAI,CAAC,CAAC,CAAC;wBAC7BT;wBACAC;oBACF;oBAEA;gBAEF;oBAAS;wBACP;oBACF;YACF;QACF;IACF;IAEA,OAAOD;AACT,EAAC"}
1
+ {"version":3,"sources":["../../src/find/traverseFields.ts"],"sourcesContent":["import type { LibSQLDatabase } from 'drizzle-orm/libsql'\nimport type { Field, JoinQuery, SelectMode, SelectType, TabAsField } from 'payload'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { combineQueries } from 'payload'\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 | TabAsField)[]\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 (\n field.type === 'collapsible' ||\n field.type === 'row' ||\n (field.type === 'tab' && !tabHasName(field))\n ) {\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 traverseFields({\n _locales,\n adapter,\n currentArgs,\n currentTableName,\n depth,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n joinQuery,\n joins,\n path,\n select,\n selectAllOnCurrentLevel,\n selectMode,\n tablePath,\n topLevelArgs,\n topLevelTableName,\n versions,\n withTabledFields,\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 '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\n case 'tab': {\n const fieldSelect = select?.[field.name]\n\n if (fieldSelect === 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 fieldSelect === 'object' ? fieldSelect : undefined,\n selectAllOnCurrentLevel:\n selectAllOnCurrentLevel ||\n fieldSelect === true ||\n (selectMode === 'exclude' && typeof fieldSelect === '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 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 joinSchemaPath = `${path.replaceAll('_', '.')}${field.name}`\n\n if (joinQuery[joinSchemaPath] === false) {\n break\n }\n\n const {\n limit: limitArg = field.defaultLimit ?? 10,\n sort = field.defaultSort,\n where,\n } = joinQuery[joinSchemaPath] || {}\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 case 'point': {\n if (adapter.name === 'sqlite') {\n break\n }\n\n const args = field.localized ? _locales : currentArgs\n if (!args.columns) {\n args.columns = {}\n }\n\n if (!args.extras) {\n args.extras = {}\n }\n\n const name = `${path}${field.name}`\n\n // Drizzle handles that poorly. See https://github.com/drizzle-team/drizzle-orm/issues/2526\n // Additionally, this way we format the column value straight in the database using ST_AsGeoJSON\n args.columns[name] = false\n\n let shouldSelect = false\n\n if (select || selectAllOnCurrentLevel) {\n if (\n selectAllOnCurrentLevel ||\n (selectMode === 'include' && select[field.name] === true) ||\n (selectMode === 'exclude' && typeof select[field.name] === 'undefined')\n ) {\n shouldSelect = true\n }\n } else {\n shouldSelect = true\n }\n\n if (shouldSelect) {\n args.extras[name] = sql.raw(`ST_AsGeoJSON(${toSnakeCase(name)})::jsonb`).as(name)\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 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","map","tab","arraySelect","withArray","columns","id","_order","_parentID","orderBy","asc","arrayTableName","tableNameMap","get","tables","_locale","_uuid","arrayTableNameWithLocales","localesSuffix","undefined","Object","keys","length","blocksSelect","blocks","block","blockKey","slug","blockSelect","blockSelectMode","withBlock","_path","tableName","fieldSelect","joinSchemaPath","replaceAll","limit","limitArg","defaultLimit","sort","defaultSort","where","payload","collections","collection","config","joinCollectionTableName","buildQueryResult","subQueryWhere","joinLocalesCollectionTableName","currentIDColumn","parent","joinRelsCollectionTableName","relationshipsSuffix","columnReferenceToCurrentID","replace","RegExp","versionsSuffix","push","condition","raw","on","table","foreignColumn","constraint","chainedMethods","args","method","db","drizzle","subQuery","methods","query","from","column","order","columnName","jsonObjectSelect","extras","as","shouldSelect","withSelect","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,IA8BlB,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,17 +1,19 @@
1
1
  import toSnakeCase from 'to-snake-case';
2
2
  import { findMany } from './find/findMany.js';
3
- export const find = async function find({ collection, 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
- const sort = typeof sortArg === 'string' ? sortArg : collectionConfig.defaultSort;
5
+ const sort = sortArg !== undefined && sortArg !== null ? sortArg : collectionConfig.defaultSort;
6
6
  const tableName = this.tableNameMap.get(toSnakeCase(collectionConfig.slug));
7
7
  return findMany({
8
8
  adapter: this,
9
9
  fields: collectionConfig.fields,
10
+ joins,
10
11
  limit,
11
12
  locale,
12
13
  page,
13
14
  pagination,
14
15
  req,
16
+ select,
15
17
  sort,
16
18
  tableName,
17
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 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 = typeof sortArg === 'string' ? 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 limit,\n locale,\n page,\n pagination,\n req,\n sort,\n tableName,\n where,\n })\n}\n"],"names":["toSnakeCase","findMany","find","collection","limit","locale","page","pagination","req","sort","sortArg","where","collectionConfig","payload","collections","config","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,MAAM,EACNC,OAAO,CAAC,EACRC,UAAU,EACVC,MAAM,CAAC,CAAmB,EAC1BC,MAAMC,OAAO,EACbC,KAAK,EACN;IAED,MAAMC,mBAA8C,IAAI,CAACC,OAAO,CAACC,WAAW,CAACX,WAAW,CAACY,MAAM;IAC/F,MAAMN,OAAO,OAAOC,YAAY,WAAWA,UAAUE,iBAAiBI,WAAW;IAEjF,MAAMC,YAAY,IAAI,CAACC,YAAY,CAACC,GAAG,CAACnB,YAAYY,iBAAiBQ,IAAI;IAEzE,OAAOnB,SAAS;QACdoB,SAAS,IAAI;QACbC,QAAQV,iBAAiBU,MAAM;QAC/BlB;QACAC;QACAC;QACAC;QACAC;QACAC;QACAQ;QACAN;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"}