@payloadcms/drizzle 3.0.0-canary.f1f97ff → 3.0.0-canary.fb04843

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 (331) 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 +15 -0
  35. package/dist/exports/postgres.d.ts.map +1 -0
  36. package/dist/exports/postgres.js +16 -0
  37. package/dist/exports/postgres.js.map +1 -0
  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 +359 -69
  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 +1 -1
  74. package/dist/migrate.d.ts.map +1 -1
  75. package/dist/migrate.js +8 -10
  76. package/dist/migrate.js.map +1 -1
  77. package/dist/migrateDown.d.ts.map +1 -1
  78. package/dist/migrateDown.js +1 -1
  79. package/dist/migrateDown.js.map +1 -1
  80. package/dist/migrateFresh.d.ts.map +1 -1
  81. package/dist/migrateFresh.js +4 -0
  82. package/dist/migrateFresh.js.map +1 -1
  83. package/dist/migrateRefresh.d.ts.map +1 -1
  84. package/dist/migrateRefresh.js +2 -1
  85. package/dist/migrateRefresh.js.map +1 -1
  86. package/dist/migrateReset.d.ts.map +1 -1
  87. package/dist/migrateReset.js +5 -3
  88. package/dist/migrateReset.js.map +1 -1
  89. package/dist/migrateStatus.js +0 -1
  90. package/dist/migrateStatus.js.map +1 -1
  91. package/dist/postgres/countDistinct.d.ts +3 -0
  92. package/dist/postgres/countDistinct.d.ts.map +1 -0
  93. package/dist/postgres/countDistinct.js +23 -0
  94. package/dist/postgres/countDistinct.js.map +1 -0
  95. package/dist/postgres/createDatabase.d.ts +14 -0
  96. package/dist/postgres/createDatabase.d.ts.map +1 -0
  97. package/dist/postgres/createDatabase.js +76 -0
  98. package/dist/postgres/createDatabase.js.map +1 -0
  99. package/dist/postgres/createExtensions.d.ts +3 -0
  100. package/dist/postgres/createExtensions.d.ts.map +1 -0
  101. package/dist/postgres/createExtensions.js +16 -0
  102. package/dist/postgres/createExtensions.js.map +1 -0
  103. package/dist/postgres/createJSONQuery/index.d.ts +3 -0
  104. package/dist/postgres/createJSONQuery/index.d.ts.map +1 -0
  105. package/dist/postgres/createJSONQuery/index.js +42 -0
  106. package/dist/postgres/createJSONQuery/index.js.map +1 -0
  107. package/dist/postgres/createMigration.d.ts +3 -0
  108. package/dist/postgres/createMigration.d.ts.map +1 -0
  109. package/dist/postgres/createMigration.js +88 -0
  110. package/dist/postgres/createMigration.js.map +1 -0
  111. package/dist/postgres/defaultSnapshot.d.ts +3 -0
  112. package/dist/postgres/defaultSnapshot.d.ts.map +1 -0
  113. package/dist/postgres/defaultSnapshot.js +20 -0
  114. package/dist/postgres/defaultSnapshot.js.map +1 -0
  115. package/dist/postgres/deleteWhere.d.ts +3 -0
  116. package/dist/postgres/deleteWhere.d.ts.map +1 -0
  117. package/dist/postgres/deleteWhere.js +6 -0
  118. package/dist/postgres/deleteWhere.js.map +1 -0
  119. package/dist/postgres/dropDatabase.d.ts +3 -0
  120. package/dist/postgres/dropDatabase.d.ts.map +1 -0
  121. package/dist/postgres/dropDatabase.js +9 -0
  122. package/dist/postgres/dropDatabase.js.map +1 -0
  123. package/dist/postgres/execute.d.ts +3 -0
  124. package/dist/postgres/execute.d.ts.map +1 -0
  125. package/dist/postgres/execute.js +11 -0
  126. package/dist/postgres/execute.js.map +1 -0
  127. package/dist/postgres/getMigrationTemplate.d.ts +4 -0
  128. package/dist/postgres/getMigrationTemplate.d.ts.map +1 -0
  129. package/dist/postgres/getMigrationTemplate.js +13 -0
  130. package/dist/postgres/getMigrationTemplate.js.map +1 -0
  131. package/dist/postgres/init.d.ts +3 -0
  132. package/dist/postgres/init.d.ts.map +1 -0
  133. package/dist/postgres/init.js +104 -0
  134. package/dist/postgres/init.js.map +1 -0
  135. package/dist/postgres/insert.d.ts +3 -0
  136. package/dist/postgres/insert.d.ts.map +1 -0
  137. package/dist/postgres/insert.js +12 -0
  138. package/dist/postgres/insert.js.map +1 -0
  139. package/dist/postgres/requireDrizzleKit.d.ts +3 -0
  140. package/dist/postgres/requireDrizzleKit.d.ts.map +1 -0
  141. package/dist/postgres/requireDrizzleKit.js +5 -0
  142. package/dist/postgres/requireDrizzleKit.js.map +1 -0
  143. package/dist/postgres/schema/build.d.ts +42 -0
  144. package/dist/postgres/schema/build.d.ts.map +1 -0
  145. package/dist/postgres/schema/build.js +404 -0
  146. package/dist/postgres/schema/build.js.map +1 -0
  147. package/dist/postgres/schema/createIndex.d.ts +11 -0
  148. package/dist/postgres/schema/createIndex.d.ts.map +1 -0
  149. package/dist/postgres/schema/createIndex.js +20 -0
  150. package/dist/postgres/schema/createIndex.js.map +1 -0
  151. package/dist/postgres/schema/geometryColumn.d.ts +12 -0
  152. package/dist/postgres/schema/geometryColumn.d.ts.map +1 -0
  153. package/dist/postgres/schema/geometryColumn.js +18 -0
  154. package/dist/postgres/schema/geometryColumn.js.map +1 -0
  155. package/dist/postgres/schema/idToUUID.d.ts +3 -0
  156. package/dist/postgres/schema/idToUUID.d.ts.map +1 -0
  157. package/dist/postgres/schema/idToUUID.js +11 -0
  158. package/dist/postgres/schema/idToUUID.js.map +1 -0
  159. package/dist/postgres/schema/parentIDColumnMap.d.ts +4 -0
  160. package/dist/postgres/schema/parentIDColumnMap.d.ts.map +1 -0
  161. package/dist/postgres/schema/parentIDColumnMap.js +9 -0
  162. package/dist/postgres/schema/parentIDColumnMap.js.map +1 -0
  163. package/dist/postgres/schema/setColumnID.d.ts +11 -0
  164. package/dist/postgres/schema/setColumnID.d.ts.map +1 -0
  165. package/dist/postgres/schema/setColumnID.js +24 -0
  166. package/dist/postgres/schema/setColumnID.js.map +1 -0
  167. package/dist/postgres/schema/traverseFields.d.ts +42 -0
  168. package/dist/postgres/schema/traverseFields.d.ts.map +1 -0
  169. package/dist/postgres/schema/traverseFields.js +743 -0
  170. package/dist/postgres/schema/traverseFields.js.map +1 -0
  171. package/dist/postgres/schema/withDefault.d.ts +4 -0
  172. package/dist/postgres/schema/withDefault.d.ts.map +1 -0
  173. package/dist/postgres/schema/withDefault.js +15 -0
  174. package/dist/postgres/schema/withDefault.js.map +1 -0
  175. package/dist/postgres/types.d.ts +142 -0
  176. package/dist/postgres/types.d.ts.map +1 -0
  177. package/dist/postgres/types.js +3 -0
  178. package/dist/postgres/types.js.map +1 -0
  179. package/dist/queries/addJoinTable.d.ts +11 -0
  180. package/dist/queries/addJoinTable.d.ts.map +1 -0
  181. package/dist/queries/addJoinTable.js +13 -0
  182. package/dist/queries/addJoinTable.js.map +1 -0
  183. package/dist/queries/buildAndOrConditions.d.ts +1 -1
  184. package/dist/queries/buildAndOrConditions.d.ts.map +1 -1
  185. package/dist/queries/buildAndOrConditions.js +2 -4
  186. package/dist/queries/buildAndOrConditions.js.map +1 -1
  187. package/dist/queries/buildOrderBy.d.ts +18 -0
  188. package/dist/queries/buildOrderBy.d.ts.map +1 -0
  189. package/dist/queries/buildOrderBy.js +56 -0
  190. package/dist/queries/buildOrderBy.js.map +1 -0
  191. package/dist/queries/buildQuery.d.ts +8 -7
  192. package/dist/queries/buildQuery.d.ts.map +1 -1
  193. package/dist/queries/buildQuery.js +12 -47
  194. package/dist/queries/buildQuery.js.map +1 -1
  195. package/dist/queries/getTableColumnFromPath.d.ts +6 -2
  196. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  197. package/dist/queries/getTableColumnFromPath.js +271 -224
  198. package/dist/queries/getTableColumnFromPath.js.map +1 -1
  199. package/dist/queries/operatorMap.d.ts.map +1 -1
  200. package/dist/queries/operatorMap.js +0 -4
  201. package/dist/queries/operatorMap.js.map +1 -1
  202. package/dist/queries/parseParams.d.ts +1 -1
  203. package/dist/queries/parseParams.d.ts.map +1 -1
  204. package/dist/queries/parseParams.js +85 -6
  205. package/dist/queries/parseParams.js.map +1 -1
  206. package/dist/queries/sanitizeQueryValue.d.ts +12 -1
  207. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
  208. package/dist/queries/sanitizeQueryValue.js +89 -25
  209. package/dist/queries/sanitizeQueryValue.js.map +1 -1
  210. package/dist/queries/selectDistinct.d.ts +3 -4
  211. package/dist/queries/selectDistinct.d.ts.map +1 -1
  212. package/dist/queries/selectDistinct.js.map +1 -1
  213. package/dist/queryDrafts.d.ts.map +1 -1
  214. package/dist/queryDrafts.js +6 -6
  215. package/dist/queryDrafts.js.map +1 -1
  216. package/dist/transactions/beginTransaction.d.ts.map +1 -1
  217. package/dist/transactions/beginTransaction.js +5 -1
  218. package/dist/transactions/beginTransaction.js.map +1 -1
  219. package/dist/transactions/commitTransaction.d.ts.map +1 -1
  220. package/dist/transactions/commitTransaction.js +3 -1
  221. package/dist/transactions/commitTransaction.js.map +1 -1
  222. package/dist/transform/read/hasManyNumber.d.ts +2 -1
  223. package/dist/transform/read/hasManyNumber.d.ts.map +1 -1
  224. package/dist/transform/read/hasManyNumber.js +12 -2
  225. package/dist/transform/read/hasManyNumber.js.map +1 -1
  226. package/dist/transform/read/hasManyText.d.ts +2 -1
  227. package/dist/transform/read/hasManyText.d.ts.map +1 -1
  228. package/dist/transform/read/hasManyText.js +12 -2
  229. package/dist/transform/read/hasManyText.js.map +1 -1
  230. package/dist/transform/read/index.d.ts +3 -2
  231. package/dist/transform/read/index.d.ts.map +1 -1
  232. package/dist/transform/read/index.js +3 -2
  233. package/dist/transform/read/index.js.map +1 -1
  234. package/dist/transform/read/relationship.d.ts +2 -1
  235. package/dist/transform/read/relationship.d.ts.map +1 -1
  236. package/dist/transform/read/relationship.js +15 -6
  237. package/dist/transform/read/relationship.js.map +1 -1
  238. package/dist/transform/read/traverseFields.d.ts +10 -2
  239. package/dist/transform/read/traverseFields.d.ts.map +1 -1
  240. package/dist/transform/read/traverseFields.js +185 -71
  241. package/dist/transform/read/traverseFields.js.map +1 -1
  242. package/dist/transform/write/array.d.ts +6 -1
  243. package/dist/transform/write/array.d.ts.map +1 -1
  244. package/dist/transform/write/array.js +7 -3
  245. package/dist/transform/write/array.js.map +1 -1
  246. package/dist/transform/write/blocks.d.ts +8 -3
  247. package/dist/transform/write/blocks.d.ts.map +1 -1
  248. package/dist/transform/write/blocks.js +19 -7
  249. package/dist/transform/write/blocks.js.map +1 -1
  250. package/dist/transform/write/index.d.ts.map +1 -1
  251. package/dist/transform/write/index.js +1 -1
  252. package/dist/transform/write/index.js.map +1 -1
  253. package/dist/transform/write/relationships.d.ts.map +1 -1
  254. package/dist/transform/write/relationships.js +6 -2
  255. package/dist/transform/write/relationships.js.map +1 -1
  256. package/dist/transform/write/selects.d.ts.map +1 -1
  257. package/dist/transform/write/selects.js +1 -1
  258. package/dist/transform/write/selects.js.map +1 -1
  259. package/dist/transform/write/traverseFields.d.ts +6 -1
  260. package/dist/transform/write/traverseFields.d.ts.map +1 -1
  261. package/dist/transform/write/traverseFields.js +62 -19
  262. package/dist/transform/write/traverseFields.js.map +1 -1
  263. package/dist/types.d.ts +8 -6
  264. package/dist/types.d.ts.map +1 -1
  265. package/dist/types.js.map +1 -1
  266. package/dist/update.d.ts.map +1 -1
  267. package/dist/update.js +4 -2
  268. package/dist/update.js.map +1 -1
  269. package/dist/updateGlobal.d.ts +1 -1
  270. package/dist/updateGlobal.d.ts.map +1 -1
  271. package/dist/updateGlobal.js +2 -1
  272. package/dist/updateGlobal.js.map +1 -1
  273. package/dist/updateGlobalVersion.d.ts +1 -1
  274. package/dist/updateGlobalVersion.d.ts.map +1 -1
  275. package/dist/updateGlobalVersion.js +4 -3
  276. package/dist/updateGlobalVersion.js.map +1 -1
  277. package/dist/updateVersion.d.ts +1 -1
  278. package/dist/updateVersion.d.ts.map +1 -1
  279. package/dist/updateVersion.js +4 -3
  280. package/dist/updateVersion.js.map +1 -1
  281. package/dist/upsertRow/deleteExistingRowsByPath.d.ts.map +1 -1
  282. package/dist/upsertRow/deleteExistingRowsByPath.js +6 -2
  283. package/dist/upsertRow/deleteExistingRowsByPath.js.map +1 -1
  284. package/dist/upsertRow/index.d.ts +1 -1
  285. package/dist/upsertRow/index.d.ts.map +1 -1
  286. package/dist/upsertRow/index.js +51 -12
  287. package/dist/upsertRow/index.js.map +1 -1
  288. package/dist/upsertRow/insertArrays.d.ts.map +1 -1
  289. package/dist/upsertRow/insertArrays.js +5 -2
  290. package/dist/upsertRow/insertArrays.js.map +1 -1
  291. package/dist/upsertRow/types.d.ts +10 -5
  292. package/dist/upsertRow/types.d.ts.map +1 -1
  293. package/dist/upsertRow/types.js.map +1 -1
  294. package/dist/utilities/buildIndexName.d.ts +7 -0
  295. package/dist/utilities/buildIndexName.d.ts.map +1 -0
  296. package/dist/utilities/buildIndexName.js +14 -0
  297. package/dist/utilities/buildIndexName.js.map +1 -0
  298. package/dist/utilities/createBlocksMap.d.ts.map +1 -1
  299. package/dist/utilities/createBlocksMap.js +4 -2
  300. package/dist/utilities/createBlocksMap.js.map +1 -1
  301. package/dist/utilities/createRelationshipMap.d.ts.map +1 -1
  302. package/dist/utilities/createRelationshipMap.js +3 -1
  303. package/dist/utilities/createRelationshipMap.js.map +1 -1
  304. package/dist/utilities/executeSchemaHooks.d.ts +24 -0
  305. package/dist/utilities/executeSchemaHooks.d.ts.map +1 -0
  306. package/dist/utilities/executeSchemaHooks.js +21 -0
  307. package/dist/utilities/executeSchemaHooks.js.map +1 -0
  308. package/dist/utilities/extendDrizzleTable.d.ts +19 -0
  309. package/dist/utilities/extendDrizzleTable.d.ts.map +1 -0
  310. package/dist/utilities/extendDrizzleTable.js +38 -0
  311. package/dist/utilities/extendDrizzleTable.js.map +1 -0
  312. package/dist/utilities/getCollectionIdType.d.ts +7 -0
  313. package/dist/utilities/getCollectionIdType.d.ts.map +1 -0
  314. package/dist/utilities/getCollectionIdType.js +11 -0
  315. package/dist/utilities/getCollectionIdType.js.map +1 -0
  316. package/dist/utilities/getNameFromDrizzleTable.d.ts +3 -0
  317. package/dist/utilities/getNameFromDrizzleTable.d.ts.map +1 -0
  318. package/dist/utilities/getNameFromDrizzleTable.js +6 -0
  319. package/dist/utilities/getNameFromDrizzleTable.js.map +1 -0
  320. package/dist/utilities/hasLocalesTable.d.ts.map +1 -1
  321. package/dist/utilities/hasLocalesTable.js +13 -3
  322. package/dist/utilities/hasLocalesTable.js.map +1 -1
  323. package/dist/utilities/isPolymorphicRelationship.d.ts +6 -0
  324. package/dist/utilities/isPolymorphicRelationship.d.ts.map +1 -0
  325. package/dist/utilities/isPolymorphicRelationship.js +5 -0
  326. package/dist/utilities/isPolymorphicRelationship.js.map +1 -0
  327. package/dist/utilities/pushDevSchema.d.ts.map +1 -1
  328. package/dist/utilities/pushDevSchema.js +5 -0
  329. package/dist/utilities/pushDevSchema.js.map +1 -1
  330. package/license.md +22 -0
  331. package/package.json +26 -10
@@ -1,56 +1,21 @@
1
- import { asc, desc } from 'drizzle-orm';
2
- import { getTableColumnFromPath } from './getTableColumnFromPath.js';
1
+ import { buildOrderBy } from './buildOrderBy.js';
3
2
  import { parseParams } from './parseParams.js';
4
- const buildQuery = async function buildQuery({ adapter, fields, locale, sort, tableName, where: incomingWhere }) {
3
+ const buildQuery = function buildQuery({ adapter, fields, joins = [], locale, sort, tableName, where: incomingWhere }) {
5
4
  const selectFields = {
6
5
  id: adapter.tables[tableName].id
7
6
  };
8
- const joins = [];
9
- const orderBy = {
10
- column: null,
11
- order: null
12
- };
13
- if (sort) {
14
- let sortPath;
15
- if (sort[0] === '-') {
16
- sortPath = sort.substring(1);
17
- orderBy.order = desc;
18
- } else {
19
- sortPath = sort;
20
- orderBy.order = asc;
21
- }
22
- try {
23
- const { columnName: sortTableColumnName, table: sortTable } = getTableColumnFromPath({
24
- adapter,
25
- collectionPath: sortPath,
26
- fields,
27
- joins,
28
- locale,
29
- pathSegments: sortPath.replace(/__/g, '.').split('.'),
30
- selectFields,
31
- tableName,
32
- value: sortPath
33
- });
34
- orderBy.column = sortTable?.[sortTableColumnName];
35
- } catch (err) {
36
- // continue
37
- }
38
- }
39
- if (!orderBy?.column) {
40
- orderBy.order = desc;
41
- const createdAt = adapter.tables[tableName]?.createdAt;
42
- if (createdAt) {
43
- orderBy.column = createdAt;
44
- } else {
45
- orderBy.column = adapter.tables[tableName].id;
46
- }
47
- }
48
- if (orderBy.column) {
49
- selectFields.sort = orderBy.column;
50
- }
7
+ const orderBy = buildOrderBy({
8
+ adapter,
9
+ fields,
10
+ joins,
11
+ locale,
12
+ selectFields,
13
+ sort,
14
+ tableName
15
+ });
51
16
  let where;
52
17
  if (incomingWhere && Object.keys(incomingWhere).length > 0) {
53
- where = await parseParams({
18
+ where = parseParams({
54
19
  adapter,
55
20
  fields,
56
21
  joins,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/queries/buildQuery.ts"],"sourcesContent":["import type { SQL } from 'drizzle-orm'\nimport type { PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport type { Field, Where } from 'payload'\n\nimport { asc, desc } from 'drizzle-orm'\n\nimport type { DrizzleAdapter, GenericColumn, GenericTable } from '../types.js'\n\nimport { getTableColumnFromPath } from './getTableColumnFromPath.js'\nimport { parseParams } from './parseParams.js'\n\nexport type BuildQueryJoinAliases = {\n condition: SQL\n table: GenericTable | PgTableWithColumns<any>\n}[]\n\ntype BuildQueryArgs = {\n adapter: DrizzleAdapter\n fields: Field[]\n locale?: string\n sort?: string\n tableName: string\n where: Where\n}\n\ntype Result = {\n joins: BuildQueryJoinAliases\n orderBy: {\n column: GenericColumn\n order: typeof asc | typeof desc\n }\n selectFields: Record<string, GenericColumn>\n where: SQL\n}\nconst buildQuery = async function buildQuery({\n adapter,\n fields,\n locale,\n sort,\n tableName,\n where: incomingWhere,\n}: BuildQueryArgs): Promise<Result> {\n const selectFields: Record<string, GenericColumn> = {\n id: adapter.tables[tableName].id,\n }\n const joins: BuildQueryJoinAliases = []\n\n const orderBy: Result['orderBy'] = {\n column: null,\n order: null,\n }\n\n if (sort) {\n let sortPath\n\n if (sort[0] === '-') {\n sortPath = sort.substring(1)\n orderBy.order = desc\n } else {\n sortPath = sort\n orderBy.order = asc\n }\n\n try {\n const { columnName: sortTableColumnName, table: sortTable } = getTableColumnFromPath({\n adapter,\n collectionPath: sortPath,\n fields,\n joins,\n locale,\n pathSegments: sortPath.replace(/__/g, '.').split('.'),\n selectFields,\n tableName,\n value: sortPath,\n })\n orderBy.column = sortTable?.[sortTableColumnName]\n } catch (err) {\n // continue\n }\n }\n\n if (!orderBy?.column) {\n orderBy.order = desc\n const createdAt = adapter.tables[tableName]?.createdAt\n\n if (createdAt) {\n orderBy.column = createdAt\n } else {\n orderBy.column = adapter.tables[tableName].id\n }\n }\n\n if (orderBy.column) {\n selectFields.sort = orderBy.column\n }\n\n let where: SQL\n\n if (incomingWhere && Object.keys(incomingWhere).length > 0) {\n where = await parseParams({\n adapter,\n fields,\n joins,\n locale,\n selectFields,\n tableName,\n where: incomingWhere,\n })\n }\n\n return {\n joins,\n orderBy,\n selectFields,\n where,\n }\n}\n\nexport default buildQuery\n"],"names":["asc","desc","getTableColumnFromPath","parseParams","buildQuery","adapter","fields","locale","sort","tableName","where","incomingWhere","selectFields","id","tables","joins","orderBy","column","order","sortPath","substring","columnName","sortTableColumnName","table","sortTable","collectionPath","pathSegments","replace","split","value","err","createdAt","Object","keys","length"],"mappings":"AAIA,SAASA,GAAG,EAAEC,IAAI,QAAQ,cAAa;AAIvC,SAASC,sBAAsB,QAAQ,8BAA6B;AACpE,SAASC,WAAW,QAAQ,mBAAkB;AAyB9C,MAAMC,aAAa,eAAeA,WAAW,EAC3CC,OAAO,EACPC,MAAM,EACNC,MAAM,EACNC,IAAI,EACJC,SAAS,EACTC,OAAOC,aAAa,EACL;IACf,MAAMC,eAA8C;QAClDC,IAAIR,QAAQS,MAAM,CAACL,UAAU,CAACI,EAAE;IAClC;IACA,MAAME,QAA+B,EAAE;IAEvC,MAAMC,UAA6B;QACjCC,QAAQ;QACRC,OAAO;IACT;IAEA,IAAIV,MAAM;QACR,IAAIW;QAEJ,IAAIX,IAAI,CAAC,EAAE,KAAK,KAAK;YACnBW,WAAWX,KAAKY,SAAS,CAAC;YAC1BJ,QAAQE,KAAK,GAAGjB;QAClB,OAAO;YACLkB,WAAWX;YACXQ,QAAQE,KAAK,GAAGlB;QAClB;QAEA,IAAI;YACF,MAAM,EAAEqB,YAAYC,mBAAmB,EAAEC,OAAOC,SAAS,EAAE,GAAGtB,uBAAuB;gBACnFG;gBACAoB,gBAAgBN;gBAChBb;gBACAS;gBACAR;gBACAmB,cAAcP,SAASQ,OAAO,CAAC,OAAO,KAAKC,KAAK,CAAC;gBACjDhB;gBACAH;gBACAoB,OAAOV;YACT;YACAH,QAAQC,MAAM,GAAGO,WAAW,CAACF,oBAAoB;QACnD,EAAE,OAAOQ,KAAK;QACZ,WAAW;QACb;IACF;IAEA,IAAI,CAACd,SAASC,QAAQ;QACpBD,QAAQE,KAAK,GAAGjB;QAChB,MAAM8B,YAAY1B,QAAQS,MAAM,CAACL,UAAU,EAAEsB;QAE7C,IAAIA,WAAW;YACbf,QAAQC,MAAM,GAAGc;QACnB,OAAO;YACLf,QAAQC,MAAM,GAAGZ,QAAQS,MAAM,CAACL,UAAU,CAACI,EAAE;QAC/C;IACF;IAEA,IAAIG,QAAQC,MAAM,EAAE;QAClBL,aAAaJ,IAAI,GAAGQ,QAAQC,MAAM;IACpC;IAEA,IAAIP;IAEJ,IAAIC,iBAAiBqB,OAAOC,IAAI,CAACtB,eAAeuB,MAAM,GAAG,GAAG;QAC1DxB,QAAQ,MAAMP,YAAY;YACxBE;YACAC;YACAS;YACAR;YACAK;YACAH;YACAC,OAAOC;QACT;IACF;IAEA,OAAO;QACLI;QACAC;QACAJ;QACAF;IACF;AACF;AAEA,eAAeN,WAAU"}
1
+ {"version":3,"sources":["../../src/queries/buildQuery.ts"],"sourcesContent":["import type { asc, desc, SQL } from 'drizzle-orm'\nimport type { PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport type { Field, Sort, Where } from 'payload'\n\nimport type { DrizzleAdapter, GenericColumn, GenericTable } from '../types.js'\n\nimport { buildOrderBy } from './buildOrderBy.js'\nimport { parseParams } from './parseParams.js'\n\nexport type BuildQueryJoinAliases = {\n condition: SQL\n table: GenericTable | PgTableWithColumns<any>\n type?: 'innerJoin' | 'leftJoin' | 'rightJoin'\n}[]\n\ntype BuildQueryArgs = {\n adapter: DrizzleAdapter\n fields: Field[]\n joins?: BuildQueryJoinAliases\n locale?: string\n sort?: Sort\n tableName: string\n where: Where\n}\n\nexport type BuildQueryResult = {\n joins: BuildQueryJoinAliases\n orderBy: {\n column: GenericColumn\n order: typeof asc | typeof desc\n }[]\n selectFields: Record<string, GenericColumn>\n where: SQL\n}\nconst buildQuery = function buildQuery({\n adapter,\n fields,\n joins = [],\n locale,\n sort,\n tableName,\n where: incomingWhere,\n}: BuildQueryArgs): BuildQueryResult {\n const selectFields: Record<string, GenericColumn> = {\n id: adapter.tables[tableName].id,\n }\n\n const orderBy = buildOrderBy({\n adapter,\n fields,\n joins,\n locale,\n selectFields,\n sort,\n tableName,\n })\n\n let where: SQL\n\n if (incomingWhere && Object.keys(incomingWhere).length > 0) {\n where = parseParams({\n adapter,\n fields,\n joins,\n locale,\n selectFields,\n tableName,\n where: incomingWhere,\n })\n }\n\n return {\n joins,\n orderBy,\n selectFields,\n where,\n }\n}\n\nexport default buildQuery\n"],"names":["buildOrderBy","parseParams","buildQuery","adapter","fields","joins","locale","sort","tableName","where","incomingWhere","selectFields","id","tables","orderBy","Object","keys","length"],"mappings":"AAMA,SAASA,YAAY,QAAQ,oBAAmB;AAChD,SAASC,WAAW,QAAQ,mBAAkB;AA2B9C,MAAMC,aAAa,SAASA,WAAW,EACrCC,OAAO,EACPC,MAAM,EACNC,QAAQ,EAAE,EACVC,MAAM,EACNC,IAAI,EACJC,SAAS,EACTC,OAAOC,aAAa,EACL;IACf,MAAMC,eAA8C;QAClDC,IAAIT,QAAQU,MAAM,CAACL,UAAU,CAACI,EAAE;IAClC;IAEA,MAAME,UAAUd,aAAa;QAC3BG;QACAC;QACAC;QACAC;QACAK;QACAJ;QACAC;IACF;IAEA,IAAIC;IAEJ,IAAIC,iBAAiBK,OAAOC,IAAI,CAACN,eAAeO,MAAM,GAAG,GAAG;QAC1DR,QAAQR,YAAY;YAClBE;YACAC;YACAC;YACAC;YACAK;YACAH;YACAC,OAAOC;QACT;IACF;IAEA,OAAO;QACLL;QACAS;QACAH;QACAF;IACF;AACF;AAEA,eAAeP,WAAU"}
@@ -1,7 +1,7 @@
1
1
  import type { SQL } from 'drizzle-orm';
2
- import type { PgTableWithColumns } from 'drizzle-orm/pg-core';
3
2
  import type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core';
4
3
  import type { Field, FieldAffectingData, TabAsField } from 'payload';
4
+ import { type PgTableWithColumns } from 'drizzle-orm/pg-core';
5
5
  import type { DrizzleAdapter, GenericColumn } from '../types.js';
6
6
  import type { BuildQueryJoinAliases } from './buildQuery.js';
7
7
  type Constraint = {
@@ -11,6 +11,10 @@ type Constraint = {
11
11
  };
12
12
  type TableColumn = {
13
13
  columnName?: string;
14
+ columns?: {
15
+ idType: 'number' | 'text' | 'uuid';
16
+ rawColumn: SQL<unknown>;
17
+ }[];
14
18
  constraints: Constraint[];
15
19
  field: FieldAffectingData;
16
20
  getNotNullColumnByValue?: (val: unknown) => string;
@@ -42,7 +46,7 @@ type Args = {
42
46
  value: unknown;
43
47
  };
44
48
  /**
45
- * Transforms path to table and column name
49
+ * Transforms path to table and column name or to a list of OR columns
46
50
  * Adds tables to `join`
47
51
  * @returns TableColumn
48
52
  */
@@ -1 +1 @@
1
- {"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AAC7D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAA;AACrE,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAe,UAAU,EAAa,MAAM,SAAS,CAAA;AAO5F,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAChE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAA;AAI5D,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;IAC5D,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;CAC7D,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,CAAC,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;IAClE,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,KAAK,EAAE,qBAAqB,CAAA;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB;;OAEG;IACH,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,8QAgBhC,IAAI,KAAG,WA8kBT,CAAA"}
1
+ {"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAA;AACrE,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAe,UAAU,EAAa,MAAM,SAAS,CAAA;AAG5F,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AAM7D,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAChE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAA;AAM5D,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;IAC5D,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,OAAO,CAAC,EAAE;QACR,MAAM,EAAE,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAA;QAClC,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;KACxB,EAAE,CAAA;IACH,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;CAC7D,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,CAAC,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAA;IAClE,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,KAAK,EAAE,qBAAqB,CAAA;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB;;OAEG;IACH,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,8QAgBhC,IAAI,KAAG,WAopBT,CAAA"}