@payloadcms/db-postgres 0.7.1 → 0.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. package/dist/count.d.ts +3 -0
  2. package/dist/count.d.ts.map +1 -0
  3. package/dist/count.js +68 -0
  4. package/dist/create.d.ts.map +1 -1
  5. package/dist/create.js +7 -9
  6. package/dist/createGlobal.d.ts +1 -1
  7. package/dist/createGlobal.d.ts.map +1 -1
  8. package/dist/createGlobal.js +8 -10
  9. package/dist/createGlobalVersion.d.ts +1 -1
  10. package/dist/createGlobalVersion.d.ts.map +1 -1
  11. package/dist/createGlobalVersion.js +12 -14
  12. package/dist/createVersion.d.ts.map +1 -1
  13. package/dist/createVersion.js +22 -19
  14. package/dist/deleteMany.js +6 -8
  15. package/dist/deleteOne.d.ts.map +1 -1
  16. package/dist/deleteOne.js +6 -3
  17. package/dist/deleteVersions.d.ts.map +1 -1
  18. package/dist/deleteVersions.js +7 -8
  19. package/dist/find/buildFindManyArgs.js +3 -3
  20. package/dist/find/findMany.js +2 -2
  21. package/dist/find/traverseFields.d.ts.map +1 -1
  22. package/dist/find/traverseFields.js +23 -11
  23. package/dist/find.d.ts.map +1 -1
  24. package/dist/find.js +10 -11
  25. package/dist/findGlobal.d.ts.map +1 -1
  26. package/dist/findGlobal.js +7 -9
  27. package/dist/findGlobalVersions.d.ts.map +1 -1
  28. package/dist/findGlobalVersions.js +7 -8
  29. package/dist/findOne.d.ts +1 -1
  30. package/dist/findOne.d.ts.map +1 -1
  31. package/dist/findOne.js +9 -10
  32. package/dist/findVersions.d.ts.map +1 -1
  33. package/dist/findVersions.js +7 -8
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.js +7 -1
  36. package/dist/init.d.ts.map +1 -1
  37. package/dist/init.js +28 -15
  38. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  39. package/dist/queries/getTableColumnFromPath.js +148 -42
  40. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
  41. package/dist/queries/sanitizeQueryValue.js +5 -2
  42. package/dist/queryDrafts.d.ts.map +1 -1
  43. package/dist/queryDrafts.js +7 -8
  44. package/dist/schema/build.d.ts +2 -1
  45. package/dist/schema/build.d.ts.map +1 -1
  46. package/dist/schema/build.js +19 -14
  47. package/dist/schema/getTableName.d.ts +32 -0
  48. package/dist/schema/getTableName.d.ts.map +1 -0
  49. package/dist/schema/getTableName.js +43 -0
  50. package/dist/schema/traverseFields.d.ts +2 -1
  51. package/dist/schema/traverseFields.d.ts.map +1 -1
  52. package/dist/schema/traverseFields.js +54 -18
  53. package/dist/schema/validateExistingBlockIsIdentical.d.ts +2 -1
  54. package/dist/schema/validateExistingBlockIsIdentical.d.ts.map +1 -1
  55. package/dist/schema/validateExistingBlockIsIdentical.js +14 -8
  56. package/dist/transform/write/blocks.d.ts +2 -2
  57. package/dist/transform/write/blocks.d.ts.map +1 -1
  58. package/dist/transform/write/blocks.js +4 -4
  59. package/dist/transform/write/traverseFields.d.ts +2 -2
  60. package/dist/transform/write/traverseFields.d.ts.map +1 -1
  61. package/dist/transform/write/traverseFields.js +34 -25
  62. package/dist/types.d.ts +13 -0
  63. package/dist/types.d.ts.map +1 -1
  64. package/dist/update.d.ts.map +1 -1
  65. package/dist/update.js +7 -4
  66. package/dist/updateGlobal.d.ts +1 -1
  67. package/dist/updateGlobal.d.ts.map +1 -1
  68. package/dist/updateGlobal.js +9 -11
  69. package/dist/updateGlobalVersion.d.ts.map +1 -1
  70. package/dist/updateGlobalVersion.js +9 -5
  71. package/dist/updateVersion.d.ts.map +1 -1
  72. package/dist/updateVersion.js +9 -5
  73. package/dist/upsertRow/index.d.ts.map +1 -1
  74. package/dist/upsertRow/index.js +7 -6
  75. package/dist/upsertRow/insertArrays.d.ts.map +1 -1
  76. package/dist/upsertRow/insertArrays.js +3 -3
  77. package/dist/upsertRow/types.d.ts +1 -1
  78. package/dist/upsertRow/types.d.ts.map +1 -1
  79. package/package.json +3 -3
@@ -54,7 +54,7 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
54
54
  if (field.type === 'number' && typeof formattedValue === 'string') {
55
55
  formattedValue = Number(val);
56
56
  }
57
- if (field.type === 'date') {
57
+ if (field.type === 'date' && operator !== 'exists') {
58
58
  if (typeof val === 'string') {
59
59
  formattedValue = new Date(val);
60
60
  if (Number.isNaN(Date.parse(formattedValue))) {
@@ -76,6 +76,9 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
76
76
  formattedValue = null;
77
77
  }
78
78
  }
79
+ if ('hasMany' in field && field.hasMany && operator === 'contains') {
80
+ operator = 'equals';
81
+ }
79
82
  if (operator === 'near' || operator === 'within' || operator === 'intersects') {
80
83
  throw new _errors.APIError(`Querying with '${operator}' is not supported with the postgres database adapter.`);
81
84
  }
@@ -94,4 +97,4 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
94
97
  };
95
98
  };
96
99
 
97
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBmaWVsZDogRmllbGQgfCBUYWJBc0ZpZWxkXG4gIG9wZXJhdG9yOiBzdHJpbmdcbiAgcmVsYXRpb25PclBhdGg6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgYWRhcHRlcixcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgcmVsYXRpb25PclBhdGgsXG4gIHZhbCxcbn06IFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MpOiB7IG9wZXJhdG9yOiBzdHJpbmc7IHZhbHVlOiB1bmtub3duIH0gPT4ge1xuICBsZXQgb3BlcmF0b3IgPSBvcGVyYXRvckFyZ1xuICBsZXQgZm9ybWF0dGVkVmFsdWUgPSB2YWxcblxuICBpZiAoIWZpZWxkQWZmZWN0c0RhdGEoZmllbGQpKSByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cblxuICBpZiAoXG4gICAgKGZpZWxkLnR5cGUgPT09ICdyZWxhdGlvbnNoaXAnIHx8IGZpZWxkLnR5cGUgPT09ICd1cGxvYWQnKSAmJlxuICAgICFyZWxhdGlvbk9yUGF0aC5lbmRzV2l0aCgncmVsYXRpb25UbycpICYmXG4gICAgQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSlcbiAgKSB7XG4gICAgY29uc3QgYWxsUG9zc2libGVJRFR5cGVzOiAobnVtYmVyIHwgc3RyaW5nKVtdID0gW11cbiAgICBmb3JtYXR0ZWRWYWx1ZS5mb3JFYWNoKCh2YWwpID0+IHtcbiAgICAgIGlmIChhZGFwdGVyLmlkVHlwZSAhPT0gJ3V1aWQnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsLCBTdHJpbmcodmFsKSlcbiAgICAgIH1cbiAgICB9KVxuICAgIGZvcm1hdHRlZFZhbHVlID0gYWxsUG9zc2libGVJRFR5cGVzXG4gIH1cblxuICAvLyBDYXN0IGluY29taW5nIHZhbHVlcyBhcyBwcm9wZXIgc2VhcmNoYWJsZSB0eXBlc1xuICBpZiAoZmllbGQudHlwZSA9PT0gJ2NoZWNrYm94JyAmJiB0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnKSBmb3JtYXR0ZWRWYWx1ZSA9IHRydWVcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICdmYWxzZScpIGZvcm1hdHRlZFZhbHVlID0gZmFsc2VcbiAgfVxuXG4gIGlmIChbJ2FsbCcsICdpbicsICdub3RfaW4nXS5pbmNsdWRlcyhvcGVyYXRvcikpIHtcbiAgICBpZiAodHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlLm1hcCgoYXJyYXlWYWwpID0+IHBhcnNlRmxvYXQoYXJyYXlWYWwpKVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSkgfHwgZm9ybWF0dGVkVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJyAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBOdW1iZXIodmFsKVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdkYXRlJykge1xuICAgIGlmICh0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgICBpZiAoTnVtYmVyLmlzTmFOKERhdGUucGFyc2UoZm9ybWF0dGVkVmFsdWUpKSkge1xuICAgICAgICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IHVuZGVmaW5lZCB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG5ldyBEYXRlKHZhbClcbiAgICB9XG4gIH1cblxuICBpZiAoWydyZWxhdGlvbnNoaXAnLCAndXBsb2FkJ10uaW5jbHVkZXMoZmllbGQudHlwZSkpIHtcbiAgICBpZiAodmFsID09PSAnbnVsbCcpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ25lYXInIHx8IG9wZXJhdG9yID09PSAnd2l0aGluJyB8fCBvcGVyYXRvciA9PT0gJ2ludGVyc2VjdHMnKSB7XG4gICAgdGhyb3cgbmV3IEFQSUVycm9yKFxuICAgICAgYFF1ZXJ5aW5nIHdpdGggJyR7b3BlcmF0b3J9JyBpcyBub3Qgc3VwcG9ydGVkIHdpdGggdGhlIHBvc3RncmVzIGRhdGFiYXNlIGFkYXB0ZXIuYCxcbiAgICApXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICdjb250YWlucycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGAlJHtmb3JtYXR0ZWRWYWx1ZX0lYFxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnZXhpc3RzJykge1xuICAgIGZvcm1hdHRlZFZhbHVlID0gZm9ybWF0dGVkVmFsdWUgPT09ICd0cnVlJyB8fCBmb3JtYXR0ZWRWYWx1ZSA9PT0gdHJ1ZVxuICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgIG9wZXJhdG9yID0gJ2lzTnVsbCdcbiAgICB9XG4gIH1cblxuICByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cbn1cbiJdLCJuYW1lcyI6WyJzYW5pdGl6ZVF1ZXJ5VmFsdWUiLCJhZGFwdGVyIiwiZmllbGQiLCJvcGVyYXRvciIsIm9wZXJhdG9yQXJnIiwicmVsYXRpb25PclBhdGgiLCJ2YWwiLCJmb3JtYXR0ZWRWYWx1ZSIsImZpZWxkQWZmZWN0c0RhdGEiLCJ2YWx1ZSIsInR5cGUiLCJlbmRzV2l0aCIsIkFycmF5IiwiaXNBcnJheSIsImFsbFBvc3NpYmxlSURUeXBlcyIsImZvckVhY2giLCJpZFR5cGUiLCJwdXNoIiwicGFyc2VJbnQiLCJTdHJpbmciLCJ0b0xvd2VyQ2FzZSIsImluY2x1ZGVzIiwiY3JlYXRlQXJyYXlGcm9tQ29tbWFEZWxpbmVhdGVkIiwibWFwIiwiYXJyYXlWYWwiLCJwYXJzZUZsb2F0IiwibGVuZ3RoIiwiTnVtYmVyIiwiRGF0ZSIsImlzTmFOIiwicGFyc2UiLCJ1bmRlZmluZWQiLCJBUElFcnJvciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFjYUE7OztlQUFBQTs7O3dCQWRZO3VCQUNxQzsyQkFD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
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBmaWVsZDogRmllbGQgfCBUYWJBc0ZpZWxkXG4gIG9wZXJhdG9yOiBzdHJpbmdcbiAgcmVsYXRpb25PclBhdGg6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgYWRhcHRlcixcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgcmVsYXRpb25PclBhdGgsXG4gIHZhbCxcbn06IFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MpOiB7IG9wZXJhdG9yOiBzdHJpbmc7IHZhbHVlOiB1bmtub3duIH0gPT4ge1xuICBsZXQgb3BlcmF0b3IgPSBvcGVyYXRvckFyZ1xuICBsZXQgZm9ybWF0dGVkVmFsdWUgPSB2YWxcblxuICBpZiAoIWZpZWxkQWZmZWN0c0RhdGEoZmllbGQpKSByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cblxuICBpZiAoXG4gICAgKGZpZWxkLnR5cGUgPT09ICdyZWxhdGlvbnNoaXAnIHx8IGZpZWxkLnR5cGUgPT09ICd1cGxvYWQnKSAmJlxuICAgICFyZWxhdGlvbk9yUGF0aC5lbmRzV2l0aCgncmVsYXRpb25UbycpICYmXG4gICAgQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSlcbiAgKSB7XG4gICAgY29uc3QgYWxsUG9zc2libGVJRFR5cGVzOiAobnVtYmVyIHwgc3RyaW5nKVtdID0gW11cbiAgICBmb3JtYXR0ZWRWYWx1ZS5mb3JFYWNoKCh2YWwpID0+IHtcbiAgICAgIGlmIChhZGFwdGVyLmlkVHlwZSAhPT0gJ3V1aWQnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsLCBTdHJpbmcodmFsKSlcbiAgICAgIH1cbiAgICB9KVxuICAgIGZvcm1hdHRlZFZhbHVlID0gYWxsUG9zc2libGVJRFR5cGVzXG4gIH1cblxuICAvLyBDYXN0IGluY29taW5nIHZhbHVlcyBhcyBwcm9wZXIgc2VhcmNoYWJsZSB0eXBlc1xuICBpZiAoZmllbGQudHlwZSA9PT0gJ2NoZWNrYm94JyAmJiB0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnKSBmb3JtYXR0ZWRWYWx1ZSA9IHRydWVcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICdmYWxzZScpIGZvcm1hdHRlZFZhbHVlID0gZmFsc2VcbiAgfVxuXG4gIGlmIChbJ2FsbCcsICdpbicsICdub3RfaW4nXS5pbmNsdWRlcyhvcGVyYXRvcikpIHtcbiAgICBpZiAodHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlLm1hcCgoYXJyYXlWYWwpID0+IHBhcnNlRmxvYXQoYXJyYXlWYWwpKVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSkgfHwgZm9ybWF0dGVkVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJyAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBOdW1iZXIodmFsKVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdkYXRlJyAmJiBvcGVyYXRvciAhPT0gJ2V4aXN0cycpIHtcbiAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IERhdGUodmFsKVxuICAgICAgaWYgKE51bWJlci5pc05hTihEYXRlLnBhcnNlKGZvcm1hdHRlZFZhbHVlKSkpIHtcbiAgICAgICAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiB1bmRlZmluZWQgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsID09PSAnbnVtYmVyJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgfVxuICB9XG5cbiAgaWYgKFsncmVsYXRpb25zaGlwJywgJ3VwbG9hZCddLmluY2x1ZGVzKGZpZWxkLnR5cGUpKSB7XG4gICAgaWYgKHZhbCA9PT0gJ251bGwnKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG51bGxcbiAgICB9XG4gIH1cblxuICBpZiAoJ2hhc01hbnknIGluIGZpZWxkICYmIGZpZWxkLmhhc01hbnkgJiYgb3BlcmF0b3IgPT09ICdjb250YWlucycpIHtcbiAgICBvcGVyYXRvciA9ICdlcXVhbHMnXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICduZWFyJyB8fCBvcGVyYXRvciA9PT0gJ3dpdGhpbicgfHwgb3BlcmF0b3IgPT09ICdpbnRlcnNlY3RzJykge1xuICAgIHRocm93IG5ldyBBUElFcnJvcihcbiAgICAgIGBRdWVyeWluZyB3aXRoICcke29wZXJhdG9yfScgaXMgbm90IHN1cHBvcnRlZCB3aXRoIHRoZSBwb3N0Z3JlcyBkYXRhYmFzZSBhZGFwdGVyLmAsXG4gICAgKVxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnY29udGFpbnMnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBgJSR7Zm9ybWF0dGVkVmFsdWV9JWBcbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ2V4aXN0cycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlID09PSAndHJ1ZScgfHwgZm9ybWF0dGVkVmFsdWUgPT09IHRydWVcbiAgICBpZiAoZm9ybWF0dGVkVmFsdWUgPT09IGZhbHNlKSB7XG4gICAgICBvcGVyYXRvciA9ICdpc051bGwnXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiBmb3JtYXR0ZWRWYWx1ZSB9XG59XG4iXSwibmFtZXMiOlsic2FuaXRpemVRdWVyeVZhbHVlIiwiYWRhcHRlciIsImZpZWxkIiwib3BlcmF0b3IiLCJvcGVyYXRvckFyZyIsInJlbGF0aW9uT3JQYXRoIiwidmFsIiwiZm9ybWF0dGVkVmFsdWUiLCJmaWVsZEFmZmVjdHNEYXRhIiwidmFsdWUiLCJ0eXBlIiwiZW5kc1dpdGgiLCJBcnJheSIsImlzQXJyYXkiLCJhbGxQb3NzaWJsZUlEVHlwZXMiLCJmb3JFYWNoIiwiaWRUeXBlIiwicHVzaCIsInBhcnNlSW50IiwiU3RyaW5nIiwidG9Mb3dlckNhc2UiLCJpbmNsdWRlcyIsImNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCIsIm1hcCIsImFycmF5VmFsIiwicGFyc2VGbG9hdCIsImxlbmd0aCIsIk51bWJlciIsIkRhdGUiLCJpc05hTiIsInBhcnNlIiwidW5kZWZpbmVkIiwiaGFzTWFueSIsIkFQSUVycm9yIl0sIm1hcHBpbmdzIjoiOzs7OytCQWNhQTs7O2VBQUFBOzs7d0JBZFk7dUJBQ3FDOzJCQUNmO0FBWXhDLE1BQU1BLHFCQUFxQixDQUFDLEVBQ2pDQyxPQUFPLEVBQ1BDLEtBQUssRUFDTEMsVUFBVUMsV0FBVyxFQUNyQkMsY0FBYyxFQUNkQyxHQUFHLEVBQ29CO0lBQ3ZCLElBQUlILFdBQVdDO0lBQ2YsSUFBSUcsaUJBQWlCRDtJQUVyQixJQUFJLENBQUNFLElBQUFBLHVCQUFnQixFQUFDTixRQUFRLE9BQU87UUFBRUM7UUFBVU0sT0FBT0Y7SUFBZTtJQUV2RSxJQUNFLEFBQUNMLENBQUFBLE1BQU1RLElBQUksS0FBSyxrQkFBa0JSLE1BQU1RLElBQUksS0FBSyxRQUFPLEtBQ3hELENBQUNMLGVBQWVNLFFBQVEsQ0FBQyxpQkFDekJDLE1BQU1DLE9BQU8sQ0FBQ04saUJBQ2Q7UUFDQSxNQUFNTyxxQkFBMEMsRUFBRTtRQUNsRFAsZUFBZVEsT0FBTyxDQUFDLENBQUNUO1lBQ3RCLElBQUlMLFFBQVFlLE1BQU0sS0FBSyxVQUFVLE9BQU9WLFFBQVEsVUFBVTtnQkFDeERRLG1CQUFtQkcsSUFBSSxDQUFDWCxLQUFLWSxTQUFTWjtZQUN4QyxPQUFPLElBQUksT0FBT0EsUUFBUSxVQUFVO2dCQUNsQ1EsbUJBQW1CRyxJQUFJLENBQUNYO1lBQzFCLE9BQU87Z0JBQ0xRLG1CQUFtQkcsSUFBSSxDQUFDWCxLQUFLYSxPQUFPYjtZQUN0QztRQUNGO1FBQ0FDLGlCQUFpQk87SUFDbkI7SUFFQSxrREFBa0Q7SUFDbEQsSUFBSVosTUFBTVEsSUFBSSxLQUFLLGNBQWMsT0FBT0osUUFBUSxVQUFVO1FBQ3hELElBQUlBLElBQUljLFdBQVcsT0FBTyxRQUFRYixpQkFBaUI7UUFDbkQsSUFBSUQsSUFBSWMsV0FBVyxPQUFPLFNBQVNiLGlCQUFpQjtJQUN0RDtJQUVBLElBQUk7UUFBQztRQUFPO1FBQU07S0FBUyxDQUFDYyxRQUFRLENBQUNsQixXQUFXO1FBQzlDLElBQUksT0FBT0ksbUJBQW1CLFVBQVU7WUFDdENBLGlCQUFpQmUsSUFBQUEseUNBQThCLEVBQUNmO1lBRWhELElBQUlMLE1BQU1RLElBQUksS0FBSyxVQUFVO2dCQUMzQkgsaUJBQWlCQSxlQUFlZ0IsR0FBRyxDQUFDLENBQUNDLFdBQWFDLFdBQVdEO1lBQy9EO1FBQ0Y7UUFFQSxJQUFJLENBQUNaLE1BQU1DLE9BQU8sQ0FBQ04sbUJBQW1CQSxlQUFlbUIsTUFBTSxLQUFLLEdBQUc7WUFDakUsT0FBTztRQUNUO0lBQ0Y7SUFFQSxJQUFJeEIsTUFBTVEsSUFBSSxLQUFLLFlBQVksT0FBT0gsbUJBQW1CLFVBQVU7UUFDakVBLGlCQUFpQm9CLE9BQU9yQjtJQUMxQjtJQUVBLElBQUlKLE1BQU1RLElBQUksS0FBSyxVQUFVUCxhQUFhLFVBQVU7UUFDbEQsSUFBSSxPQUFPRyxRQUFRLFVBQVU7WUFDM0JDLGlCQUFpQixJQUFJcUIsS0FBS3RCO1lBQzFCLElBQUlxQixPQUFPRSxLQUFLLENBQUNELEtBQUtFLEtBQUssQ0FBQ3ZCLGtCQUFrQjtnQkFDNUMsT0FBTztvQkFBRUo7b0JBQVVNLE9BQU9zQjtnQkFBVTtZQUN0QztRQUNGO1FBRUEsSUFBSSxPQUFPekIsUUFBUSxVQUFVO1lBQzNCQyxpQkFBaUIsSUFBSXFCLEtBQUt0QjtRQUM1QjtJQUNGO0lBRUEsSUFBSTtRQUFDO1FBQWdCO0tBQVMsQ0FBQ2UsUUFBUSxDQUFDbkIsTUFBTVEsSUFBSSxHQUFHO1FBQ25ELElBQUlKLFFBQVEsUUFBUTtZQUNsQkMsaUJBQWlCO1FBQ25CO0lBQ0Y7SUFFQSxJQUFJLGFBQWFMLFNBQVNBLE1BQU04QixPQUFPLElBQUk3QixhQUFhLFlBQVk7UUFDbEVBLFdBQVc7SUFDYjtJQUVBLElBQUlBLGFBQWEsVUFBVUEsYUFBYSxZQUFZQSxhQUFhLGNBQWM7UUFDN0UsTUFBTSxJQUFJOEIsZ0JBQVEsQ0FDaEIsQ0FBQyxlQUFlLEVBQUU5QixTQUFTLHNEQUFzRCxDQUFDO0lBRXRGO0lBRUEsSUFBSUEsYUFBYSxZQUFZO1FBQzNCSSxpQkFBaUIsQ0FBQyxDQUFDLEVBQUVBLGVBQWUsQ0FBQyxDQUFDO0lBQ3hDO0lBRUEsSUFBSUosYUFBYSxVQUFVO1FBQ3pCSSxpQkFBaUJBLG1CQUFtQixVQUFVQSxtQkFBbUI7UUFDakUsSUFBSUEsbUJBQW1CLE9BQU87WUFDNUJKLFdBQVc7UUFDYjtJQUNGO0lBRUEsT0FBTztRQUFFQTtRQUFVTSxPQUFPRjtJQUFlO0FBQzNDIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,WAAW,EAAkB,MAAM,kBAAkB,CAAA;AAMnE,eAAO,MAAM,WAAW,EAAE,WA2CzB,CAAA"}
1
+ {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,WAAW,EAAkB,MAAM,kBAAkB,CAAA;AAMnE,eAAO,MAAM,WAAW,EAAE,WA+CzB,CAAA"}
@@ -10,16 +10,15 @@ Object.defineProperty(exports, "queryDrafts", {
10
10
  });
11
11
  const _database = require("payload/database");
12
12
  const _versions = require("payload/versions");
13
- const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
14
13
  const _findMany = require("./find/findMany");
15
- function _interop_require_default(obj) {
16
- return obj && obj.__esModule ? obj : {
17
- default: obj
18
- };
19
- }
14
+ const _getTableName = require("./schema/getTableName");
20
15
  const queryDrafts = async function queryDrafts({ collection, limit, locale, page = 1, pagination, req = {}, sort, where }) {
21
16
  const collectionConfig = this.payload.collections[collection].config;
22
- const tableName = `_${(0, _tosnakecase.default)(collection)}_v`;
17
+ const tableName = (0, _getTableName.getTableName)({
18
+ adapter: this,
19
+ config: collectionConfig,
20
+ versions: true
21
+ });
23
22
  const fields = (0, _versions.buildVersionCollectionFields)(collectionConfig);
24
23
  const combinedWhere = (0, _database.combineQueries)({
25
24
  latest: {
@@ -53,4 +52,4 @@ const queryDrafts = async function queryDrafts({ collection, limit, locale, page
53
52
  };
54
53
  };
55
54
 
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdHlwZSBRdWVyeURyYWZ0cywgY29tYmluZVF1ZXJpZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHsgZmluZE1hbnkgfSBmcm9tICcuL2ZpbmQvZmluZE1hbnknXG5cbmV4cG9ydCBjb25zdCBxdWVyeURyYWZ0czogUXVlcnlEcmFmdHMgPSBhc3luYyBmdW5jdGlvbiBxdWVyeURyYWZ0cyh7XG4gIGNvbGxlY3Rpb24sXG4gIGxpbWl0LFxuICBsb2NhbGUsXG4gIHBhZ2UgPSAxLFxuICBwYWdpbmF0aW9uLFxuICByZXEgPSB7fSBhcyBQYXlsb2FkUmVxdWVzdCxcbiAgc29ydCxcbiAgd2hlcmUsXG59KSB7XG4gIGNvbnN0IGNvbGxlY3Rpb25Db25maWc6IFNhbml0aXplZENvbGxlY3Rpb25Db25maWcgPSB0aGlzLnBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvbl0uY29uZmlnXG4gIGNvbnN0IHRhYmxlTmFtZSA9IGBfJHt0b1NuYWtlQ2FzZShjb2xsZWN0aW9uKX1fdmBcbiAgY29uc3QgZmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uQ29uZmlnKVxuXG4gIGNvbnN0IGNvbWJpbmVkV2hlcmUgPSBjb21iaW5lUXVlcmllcyh7IGxhdGVzdDogeyBlcXVhbHM6IHRydWUgfSB9LCB3aGVyZSlcblxuICBjb25zdCByZXN1bHQgPSBhd2FpdCBmaW5kTWFueSh7XG4gICAgYWRhcHRlcjogdGhpcyxcbiAgICBmaWVsZHMsXG4gICAgbGltaXQsXG4gICAgbG9jYWxlLFxuICAgIHBhZ2UsXG4gICAgcGFnaW5hdGlvbixcbiAgICByZXEsXG4gICAgc29ydCxcbiAgICB0YWJsZU5hbWUsXG4gICAgd2hlcmU6IGNvbWJpbmVkV2hlcmUsXG4gIH0pXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHQsXG4gICAgZG9jczogcmVzdWx0LmRvY3MubWFwKChkb2MpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgICAgZG9jID0ge1xuICAgICAgICBpZDogZG9jLnBhcmVudCxcbiAgICAgICAgLi4uZG9jLnZlcnNpb24sXG4gICAgICAgIGNyZWF0ZWRBdDogZG9jLmNyZWF0ZWRBdCxcbiAgICAgICAgdXBkYXRlZEF0OiBkb2MudXBkYXRlZEF0LFxuICAgICAgfVxuXG4gICAgICByZXR1cm4gZG9jXG4gICAgfSksXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJxdWVyeURyYWZ0cyIsImNvbGxlY3Rpb24iLCJsaW1pdCIsImxvY2FsZSIsInBhZ2UiLCJwYWdpbmF0aW9uIiwicmVxIiwic29ydCIsIndoZXJlIiwiY29sbGVjdGlvbkNvbmZpZyIsInBheWxvYWQiLCJjb2xsZWN0aW9ucyIsImNvbmZpZyIsInRhYmxlTmFtZSIsInRvU25ha2VDYXNlIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsImNvbWJpbmVkV2hlcmUiLCJjb21iaW5lUXVlcmllcyIsImxhdGVzdCIsImVxdWFscyIsInJlc3VsdCIsImZpbmRNYW55IiwiYWRhcHRlciIsImRvY3MiLCJtYXAiLCJkb2MiLCJpZCIsInBhcmVudCIsInZlcnNpb24iLCJjcmVhdGVkQXQiLCJ1cGRhdGVkQXQiXSwibWFwcGluZ3MiOiI7Ozs7K0JBUWFBOzs7ZUFBQUE7OzswQkFOb0M7MEJBQ0o7b0VBQ3JCOzBCQUVDOzs7Ozs7QUFFbEIsTUFBTUEsY0FBMkIsZUFBZUEsWUFBWSxFQUNqRUMsVUFBVSxFQUNWQyxLQUFLLEVBQ0xDLE1BQU0sRUFDTkMsT0FBTyxDQUFDLEVBQ1JDLFVBQVUsRUFDVkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxJQUFJLEVBQ0pDLEtBQUssRUFDTjtJQUNDLE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDVixXQUFXLENBQUNXLE1BQU07SUFDL0YsTUFBTUMsWUFBWSxDQUFDLENBQUMsRUFBRUMsSUFBQUEsb0JBQVcsRUFBQ2IsWUFBWSxFQUFFLENBQUM7SUFDakQsTUFBTWMsU0FBU0MsSUFBQUEsc0NBQTRCLEVBQUNQO0lBRTVDLE1BQU1RLGdCQUFnQkMsSUFBQUEsd0JBQWMsRUFBQztRQUFFQyxRQUFRO1lBQUVDLFFBQVE7UUFBSztJQUFFLEdBQUdaO0lBRW5FLE1BQU1hLFNBQVMsTUFBTUMsSUFBQUEsa0JBQVEsRUFBQztRQUM1QkMsU0FBUyxJQUFJO1FBQ2JSO1FBQ0FiO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FNO1FBQ0FMLE9BQU9TO0lBQ1Q7SUFFQSxPQUFPO1FBQ0wsR0FBR0ksTUFBTTtRQUNURyxNQUFNSCxPQUFPRyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDQztZQUNyQiw2Q0FBNkM7WUFDN0NBLE1BQU07Z0JBQ0pDLElBQUlELElBQUlFLE1BQU07Z0JBQ2QsR0FBR0YsSUFBSUcsT0FBTztnQkFDZEMsV0FBV0osSUFBSUksU0FBUztnQkFDeEJDLFdBQVdMLElBQUlLLFNBQVM7WUFDMUI7WUFFQSxPQUFPTDtRQUNUO0lBQ0Y7QUFDRiJ9
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeURyYWZ0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0LCBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdHlwZSBRdWVyeURyYWZ0cywgY29tYmluZVF1ZXJpZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5cbmltcG9ydCB7IGZpbmRNYW55IH0gZnJvbSAnLi9maW5kL2ZpbmRNYW55J1xuaW1wb3J0IHsgZ2V0VGFibGVOYW1lIH0gZnJvbSAnLi9zY2hlbWEvZ2V0VGFibGVOYW1lJ1xuXG5leHBvcnQgY29uc3QgcXVlcnlEcmFmdHM6IFF1ZXJ5RHJhZnRzID0gYXN5bmMgZnVuY3Rpb24gcXVlcnlEcmFmdHMoe1xuICBjb2xsZWN0aW9uLFxuICBsaW1pdCxcbiAgbG9jYWxlLFxuICBwYWdlID0gMSxcbiAgcGFnaW5hdGlvbixcbiAgcmVxID0ge30gYXMgUGF5bG9hZFJlcXVlc3QsXG4gIHNvcnQsXG4gIHdoZXJlLFxufSkge1xuICBjb25zdCBjb2xsZWN0aW9uQ29uZmlnOiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnID0gdGhpcy5wYXlsb2FkLmNvbGxlY3Rpb25zW2NvbGxlY3Rpb25dLmNvbmZpZ1xuICBjb25zdCB0YWJsZU5hbWUgPSBnZXRUYWJsZU5hbWUoe1xuICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgY29uZmlnOiBjb2xsZWN0aW9uQ29uZmlnLFxuICAgIHZlcnNpb25zOiB0cnVlLFxuICB9KVxuICBjb25zdCBmaWVsZHMgPSBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzKGNvbGxlY3Rpb25Db25maWcpXG5cbiAgY29uc3QgY29tYmluZWRXaGVyZSA9IGNvbWJpbmVRdWVyaWVzKHsgbGF0ZXN0OiB7IGVxdWFsczogdHJ1ZSB9IH0sIHdoZXJlKVxuXG4gIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGZpbmRNYW55KHtcbiAgICBhZGFwdGVyOiB0aGlzLFxuICAgIGZpZWxkcyxcbiAgICBsaW1pdCxcbiAgICBsb2NhbGUsXG4gICAgcGFnZSxcbiAgICBwYWdpbmF0aW9uLFxuICAgIHJlcSxcbiAgICBzb3J0LFxuICAgIHRhYmxlTmFtZSxcbiAgICB3aGVyZTogY29tYmluZWRXaGVyZSxcbiAgfSlcblxuICByZXR1cm4ge1xuICAgIC4uLnJlc3VsdCxcbiAgICBkb2NzOiByZXN1bHQuZG9jcy5tYXAoKGRvYykgPT4ge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXBhcmFtLXJlYXNzaWduXG4gICAgICBkb2MgPSB7XG4gICAgICAgIGlkOiBkb2MucGFyZW50LFxuICAgICAgICAuLi5kb2MudmVyc2lvbixcbiAgICAgICAgY3JlYXRlZEF0OiBkb2MuY3JlYXRlZEF0LFxuICAgICAgICB1cGRhdGVkQXQ6IGRvYy51cGRhdGVkQXQsXG4gICAgICB9XG5cbiAgICAgIHJldHVybiBkb2NcbiAgICB9KSxcbiAgfVxufVxuIl0sIm5hbWVzIjpbInF1ZXJ5RHJhZnRzIiwiY29sbGVjdGlvbiIsImxpbWl0IiwibG9jYWxlIiwicGFnZSIsInBhZ2luYXRpb24iLCJyZXEiLCJzb3J0Iiwid2hlcmUiLCJjb2xsZWN0aW9uQ29uZmlnIiwicGF5bG9hZCIsImNvbGxlY3Rpb25zIiwiY29uZmlnIiwidGFibGVOYW1lIiwiZ2V0VGFibGVOYW1lIiwiYWRhcHRlciIsInZlcnNpb25zIiwiZmllbGRzIiwiYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyIsImNvbWJpbmVkV2hlcmUiLCJjb21iaW5lUXVlcmllcyIsImxhdGVzdCIsImVxdWFscyIsInJlc3VsdCIsImZpbmRNYW55IiwiZG9jcyIsIm1hcCIsImRvYyIsImlkIiwicGFyZW50IiwidmVyc2lvbiIsImNyZWF0ZWRBdCIsInVwZGF0ZWRBdCJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFRYUE7OztlQUFBQTs7OzBCQU5vQzswQkFDSjswQkFFcEI7OEJBQ0k7QUFFdEIsTUFBTUEsY0FBMkIsZUFBZUEsWUFBWSxFQUNqRUMsVUFBVSxFQUNWQyxLQUFLLEVBQ0xDLE1BQU0sRUFDTkMsT0FBTyxDQUFDLEVBQ1JDLFVBQVUsRUFDVkMsTUFBTSxDQUFDLENBQW1CLEVBQzFCQyxJQUFJLEVBQ0pDLEtBQUssRUFDTjtJQUNDLE1BQU1DLG1CQUE4QyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsV0FBVyxDQUFDVixXQUFXLENBQUNXLE1BQU07SUFDL0YsTUFBTUMsWUFBWUMsSUFBQUEsMEJBQVksRUFBQztRQUM3QkMsU0FBUyxJQUFJO1FBQ2JILFFBQVFIO1FBQ1JPLFVBQVU7SUFDWjtJQUNBLE1BQU1DLFNBQVNDLElBQUFBLHNDQUE0QixFQUFDVDtJQUU1QyxNQUFNVSxnQkFBZ0JDLElBQUFBLHdCQUFjLEVBQUM7UUFBRUMsUUFBUTtZQUFFQyxRQUFRO1FBQUs7SUFBRSxHQUFHZDtJQUVuRSxNQUFNZSxTQUFTLE1BQU1DLElBQUFBLGtCQUFRLEVBQUM7UUFDNUJULFNBQVMsSUFBSTtRQUNiRTtRQUNBZjtRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBQztRQUNBTTtRQUNBTCxPQUFPVztJQUNUO0lBRUEsT0FBTztRQUNMLEdBQUdJLE1BQU07UUFDVEUsTUFBTUYsT0FBT0UsSUFBSSxDQUFDQyxHQUFHLENBQUMsQ0FBQ0M7WUFDckIsNkNBQTZDO1lBQzdDQSxNQUFNO2dCQUNKQyxJQUFJRCxJQUFJRSxNQUFNO2dCQUNkLEdBQUdGLElBQUlHLE9BQU87Z0JBQ2RDLFdBQVdKLElBQUlJLFNBQVM7Z0JBQ3hCQyxXQUFXTCxJQUFJSyxTQUFTO1lBQzFCO1lBRUEsT0FBT0w7UUFDVDtJQUNGO0FBQ0YifQ==
@@ -17,12 +17,13 @@ type Args = {
17
17
  rootTableName?: string;
18
18
  tableName: string;
19
19
  timestamps?: boolean;
20
+ versions: boolean;
20
21
  };
21
22
  type Result = {
22
23
  hasManyNumberField: 'index' | boolean;
23
24
  hasManyTextField: 'index' | boolean;
24
25
  relationsToBuild: Map<string, string>;
25
26
  };
26
- export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, }: Args) => Result;
27
+ export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions, }: Args) => Result;
27
28
  export {};
28
29
  //# sourceMappingURL=build.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,YAAY,EACZ,eAAe,EAEf,uBAAuB,EACxB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAO1C,OAAO,KAAK,EAAE,cAAc,EAAwB,eAAe,EAAE,MAAM,UAAU,CAAA;AAMrF,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,8PAgBpB,IAAI,KAAG,MA+TT,CAAA"}
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,YAAY,EACZ,eAAe,EAEf,uBAAuB,EACxB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAM1C,OAAO,KAAK,EAAE,cAAc,EAAwB,eAAe,EAAE,MAAM,UAAU,CAAA;AAOrF,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,OAAO,CAAA;CAClB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,wQAiBpB,IAAI,KAAG,MAyUT,CAAA"}
@@ -11,16 +11,11 @@ Object.defineProperty(exports, "buildTable", {
11
11
  const _drizzleorm = require("drizzle-orm");
12
12
  const _pgcore = require("drizzle-orm/pg-core");
13
13
  const _types = require("payload/types");
14
- const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
14
+ const _getTableName = require("./getTableName");
15
15
  const _parentIDColumnMap = require("./parentIDColumnMap");
16
16
  const _setColumnID = require("./setColumnID");
17
17
  const _traverseFields = require("./traverseFields");
18
- function _interop_require_default(obj) {
19
- return obj && obj.__esModule ? obj : {
20
- default: obj
21
- };
22
- }
23
- const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps })=>{
18
+ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions })=>{
24
19
  const rootTableName = incomingRootTableName || tableName;
25
20
  const columns = baseColumns;
26
21
  const indexes = {};
@@ -63,7 +58,8 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
63
58
  relationships,
64
59
  rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
65
60
  rootTableIDColType: rootTableIDColType || idColType,
66
- rootTableName
61
+ rootTableName,
62
+ versions
67
63
  }));
68
64
  if (timestamps) {
69
65
  columns.createdAt = (0, _pgcore.timestamp)('created_at', {
@@ -89,7 +85,7 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
89
85
  });
90
86
  adapter.tables[tableName] = table;
91
87
  if (hasLocalizedField) {
92
- const localeTableName = `${tableName}_locales`;
88
+ const localeTableName = `${tableName}${adapter.localesSuffix}`;
93
89
  localesColumns.id = (0, _pgcore.serial)('id').primaryKey();
94
90
  localesColumns._locale = adapter.enums.enum__locales('_locale').notNull();
95
91
  localesColumns._parentID = _parentIDColumnMap.parentIDColumnMap[idColType]('_parent_id').references(()=>table.id, {
@@ -208,16 +204,21 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
208
204
  relationshipColumns.locale = adapter.enums.enum__locales('locale');
209
205
  }
210
206
  relationships.forEach((relationTo)=>{
211
- const formattedRelationTo = (0, _tosnakecase.default)(relationTo);
207
+ const relationshipConfig = adapter.payload.collections[relationTo].config;
208
+ const formattedRelationTo = (0, _getTableName.getTableName)({
209
+ adapter,
210
+ config: relationshipConfig,
211
+ throwValidationError: true
212
+ });
212
213
  let colType = adapter.idType === 'uuid' ? 'uuid' : 'integer';
213
- const relatedCollectionCustomID = adapter.payload.collections[relationTo].config.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
214
+ const relatedCollectionCustomID = relationshipConfig.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
214
215
  if (relatedCollectionCustomID?.type === 'number') colType = 'numeric';
215
216
  if (relatedCollectionCustomID?.type === 'text') colType = 'varchar';
216
217
  relationshipColumns[`${relationTo}ID`] = _parentIDColumnMap.parentIDColumnMap[colType](`${formattedRelationTo}_id`).references(()=>adapter.tables[formattedRelationTo].id, {
217
218
  onDelete: 'cascade'
218
219
  });
219
220
  });
220
- const relationshipsTableName = `${tableName}_rels`;
221
+ const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`;
221
222
  relationshipsTable = adapter.pgSchema.table(relationshipsTableName, relationshipColumns, (cols)=>{
222
223
  const result = {
223
224
  order: (0, _pgcore.index)(`${relationshipsTableName}_order_idx`).on(cols.order),
@@ -243,7 +244,11 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
243
244
  })
244
245
  };
245
246
  relationships.forEach((relationTo)=>{
246
- const relatedTableName = (0, _tosnakecase.default)(relationTo);
247
+ const relatedTableName = (0, _getTableName.getTableName)({
248
+ adapter,
249
+ config: adapter.payload.collections[relationTo].config,
250
+ throwValidationError: true
251
+ });
247
252
  const idColumnName = `${relationTo}ID`;
248
253
  result[idColumnName] = one(adapter.tables[relatedTableName], {
249
254
  fields: [
@@ -288,4 +293,4 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
288
293
  };
289
294
  };
290
295
 
291
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type {\n  IndexBuilder,\n  PgColumnBuilder,\n  PgTableWithColumns,\n  UniqueConstraintBuilder,\n} from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport { index, integer, numeric, serial, timestamp, unique, varchar } from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, IDType, PostgresAdapter } from '../types'\n\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { setColumnID } from './setColumnID'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  buildTexts?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  hasManyNumberField: 'index' | boolean\n  hasManyTextField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  buildTexts,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyTextField: 'index' | boolean = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyTextField = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable | PgTableWithColumns<any>\n  let textsTable: GenericTable | PgTableWithColumns<any>\n  let numbersTable: GenericTable | PgTableWithColumns<any>\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable | PgTableWithColumns<any>\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType: IDType = setColumnID({ adapter, columns, fields })\n\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    buildTexts,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = adapter.pgSchema.table(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = adapter.pgSchema.table(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n      text: varchar('text'),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = adapter.pgSchema.table(textsTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyTextField === 'index') {\n        indexes.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        indexes.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = adapter.pgSchema.table(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index(`${numbersTableName}_locale_parent`).on(\n          cols.locale,\n          cols.parent,\n        )\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = adapter.idType === 'uuid' ? 'uuid' : 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_rels`\n\n      relationshipsTable = adapter.pgSchema.table(\n        relationshipsTableName,\n        relationshipColumns,\n        (cols) => {\n          const result: Record<string, unknown> = {\n            order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n            parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n            pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n          }\n\n          if (hasLocalizedRelationshipField) {\n            result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n          }\n\n          return result\n        },\n      )\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyNumberField, hasManyTextField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","buildTexts","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasManyNumberField","hasLocalizedManyTextField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","setColumnID","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgSchema","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","id","serial","primaryKey","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","textsTableName","order","integer","parent","path","varchar","text","locale","orderParentIdx","index","text_idx","localeParent","textsTableRelations","numbersTableName","number","numeric","numberIdx","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","idType","relatedCollectionCustomID","payload","collections","find","field","fieldAffectsData","name","type","relationshipsTableName","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"mappings":"AAAA,oCAAoC;;;;+BA6CvBA;;;eAAAA;;;4BAnCa;wBACkD;uBAC3C;oEACT;mCAIU;6BACN;gCACG;;;;;;AA0BxB,MAAMA,aAAa,CAAC,EACzBC,OAAO,EACPC,cAAc,CAAC,CAAC,EAChBC,kBAAkB,CAAC,CAAC,EACpBC,YAAY,EACZC,kBAAkB,EAClBC,UAAU,EACVC,cAAc,EACdC,gBAAgB,KAAK,EACrBC,MAAM,EACNC,oBAAoB,EACpBC,iBAAiB,EACjBC,kBAAkB,EAClBC,eAAeC,qBAAqB,EACpCC,SAAS,EACTC,UAAU,EACL;IACL,MAAMH,gBAAgBC,yBAAyBC;IAC/C,MAAME,UAA2Cf;IACjD,MAAMgB,UAAkE,CAAC;IAEzE,IAAIC,oBAAoB;IACxB,IAAIC,gCAAgC;IACpC,IAAIC,mBAAsC;IAC1C,IAAIC,qBAAwC;IAC5C,IAAIC,4BAA4B;IAChC,IAAIC,8BAA8B;IAElC,MAAMC,iBAAkD,CAAC;IACzD,MAAMC,iBAAyE,CAAC;IAChF,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IAEJ,uCAAuC;IACvC,MAAMC,gBAA6BnB,qBAAqB,IAAIoB;IAE5D,IAAIC;IAEJ,oBAAoB;IACpB,MAAMC,mBAAwC,IAAIC;IAElD,MAAMC,YAAoBC,IAAAA,wBAAW,EAAC;QAAEnC;QAASgB;QAASR;IAAO;IAE/D,CAAA,EACAU,iBAAiB,EACjBK,2BAA2B,EAC3BD,yBAAyB,EACzBH,6BAA6B,EAC7BE,kBAAkB,EAClBD,gBAAgB,EACjB,GAAGgB,IAAAA,8BAAc,EAAC;QACjBpC;QACAG;QACAC;QACAC;QACAW;QACAV;QACAC;QACAC;QACAS;QACAO;QACAC;QACAY,cAAcvB;QACdwB,iBAAiBxB;QACjBkB;QACAH;QACApB,sBAAsBA,wBAAwBuB;QAC9CrB,oBAAoBA,sBAAsBuB;QAC1CtB;IACF,EAAC;IAED,IAAIG,YAAY;QACdC,QAAQuB,SAAS,GAAGC,IAAAA,iBAAS,EAAC,cAAc;YAC1CC,MAAM;YACNC,WAAW;YACXC,cAAc;QAChB,GACGC,UAAU,GACVC,OAAO;QACV7B,QAAQ8B,SAAS,GAAGN,IAAAA,iBAAS,EAAC,cAAc;YAC1CC,MAAM;YACNC,WAAW;YACXC,cAAc;QAChB,GACGC,UAAU,GACVC,OAAO;IACZ;IAEA,MAAME,QAAQ/C,QAAQgD,QAAQ,CAACD,KAAK,CAACjC,WAAWE,SAAS,CAACiC;QACxD,MAAMC,cAAcC,OAAOC,OAAO,CAAClD,iBAAiBmD,MAAM,CAAC,CAACC,QAAQ,CAACC,KAAKC,KAAK;YAC7EF,MAAM,CAACC,IAAI,GAAGC,KAAKP;YACnB,OAAOK;QACT,GAAG,CAAC;QAEJ,OAAOH,OAAOC,OAAO,CAACnC,SAASoC,MAAM,CAAC,CAACI,KAAK,CAACC,SAASF,KAAK;YACzDC,GAAG,CAACC,QAAQ,GAAGF,KAAKP;YACpB,OAAOQ;QACT,GAAGP;IACL;IAEAlD,QAAQ2D,MAAM,CAAC7C,UAAU,GAAGiC;IAE5B,IAAI7B,mBAAmB;QACrB,MAAM0C,kBAAkB,CAAC,EAAE9C,UAAU,QAAQ,CAAC;QAC9CU,eAAeqC,EAAE,GAAGC,IAAAA,cAAM,EAAC,MAAMC,UAAU;QAC3CvC,eAAewC,OAAO,GAAGhE,QAAQiE,KAAK,CAACC,aAAa,CAAC,WAAWrB,OAAO;QACvErB,eAAe2C,SAAS,GAAGC,oCAAiB,CAAClC,UAAU,CAAC,cACrDmC,UAAU,CAAC,IAAMtB,MAAMc,EAAE,EAAE;YAAES,UAAU;QAAU,GACjDzB,OAAO;QAEVnB,eAAe1B,QAAQgD,QAAQ,CAACD,KAAK,CAACa,iBAAiBpC,gBAAgB,CAACyB;YACtE,OAAOE,OAAOC,OAAO,CAAC3B,gBAAgB4B,MAAM,CAC1C,CAACI,KAAK,CAACC,SAASF,KAAK;gBACnBC,GAAG,CAACC,QAAQ,GAAGF,KAAKP;gBACpB,OAAOQ;YACT,GACA;gBACEc,eAAeC,IAAAA,cAAM,EAAC,CAAC,EAAEZ,gBAAgB,wBAAwB,CAAC,EAAEa,EAAE,CACpExB,KAAKe,OAAO,EACZf,KAAKkB,SAAS;YAElB;QAEJ;QAEAnE,QAAQ2D,MAAM,CAACC,gBAAgB,GAAGlC;QAElC,MAAMgD,wBAAwBC,IAAAA,qBAAS,EAACjD,cAAc,CAAC,EAAEkD,GAAG,EAAE,GAAM,CAAA;gBAClET,WAAWS,IAAI7B,OAAO;oBACpBvC,QAAQ;wBAACkB,aAAayC,SAAS;qBAAC;oBAChCE,YAAY;wBAACtB,MAAMc,EAAE;qBAAC;gBACxB;YACF,CAAA;QAEA7D,QAAQ2E,SAAS,CAAC,CAAC,UAAU,EAAEf,gBAAgB,CAAC,CAAC,GAAGc;IACtD;IAEA,IAAItD,oBAAoBf,YAAY;QAClC,MAAMwE,iBAAiB,CAAC,EAAEjE,cAAc,MAAM,CAAC;QAC/C,MAAMI,UAA2C;YAC/C6C,IAAIC,IAAAA,cAAM,EAAC,MAAMC,UAAU;YAC3Be,OAAOC,IAAAA,eAAO,EAAC,SAASlC,OAAO;YAC/BmC,QAAQZ,oCAAiB,CAAClC,UAAU,CAAC,aAClCmC,UAAU,CAAC,IAAMtB,MAAMc,EAAE,EAAE;gBAAES,UAAU;YAAU,GACjDzB,OAAO;YACVoC,MAAMC,IAAAA,eAAO,EAAC,QAAQrC,OAAO;YAC7BsC,MAAMD,IAAAA,eAAO,EAAC;QAChB;QAEA,IAAI5D,2BAA2B;YAC7BN,QAAQoE,MAAM,GAAGpF,QAAQiE,KAAK,CAACC,aAAa,CAAC;QAC/C;QAEAvC,aAAa3B,QAAQgD,QAAQ,CAACD,KAAK,CAAC8B,gBAAgB7D,SAAS,CAACiC;YAC5D,MAAMhC,UAAwC;gBAC5CoE,gBAAgBC,IAAAA,aAAK,EAAC,CAAC,EAAET,eAAe,iBAAiB,CAAC,EAAEJ,EAAE,CAACxB,KAAK6B,KAAK,EAAE7B,KAAK+B,MAAM;YACxF;YAEA,IAAI5D,qBAAqB,SAAS;gBAChCH,QAAQsE,QAAQ,GAAGD,IAAAA,aAAK,EAAC,CAAC,EAAET,eAAe,SAAS,CAAC,EAAEJ,EAAE,CAACxB,KAAKkC,IAAI;YACrE;YAEA,IAAI7D,2BAA2B;gBAC7BL,QAAQuE,YAAY,GAAGF,IAAAA,aAAK,EAAC,CAAC,EAAET,eAAe,cAAc,CAAC,EAAEJ,EAAE,CAACxB,KAAKmC,MAAM,EAAEnC,KAAK+B,MAAM;YAC7F;YAEA,OAAO/D;QACT;QAEAjB,QAAQ2D,MAAM,CAACkB,eAAe,GAAGlD;QAEjC,MAAM8D,sBAAsBd,IAAAA,qBAAS,EAAChD,YAAY,CAAC,EAAEiD,GAAG,EAAE,GAAM,CAAA;gBAC9DI,QAAQJ,IAAI7B,OAAO;oBACjBvC,QAAQ;wBAACmB,WAAWqD,MAAM;qBAAC;oBAC3BX,YAAY;wBAACtB,MAAMc,EAAE;qBAAC;gBACxB;YACF,CAAA;QAEA7D,QAAQ2E,SAAS,CAAC,CAAC,UAAU,EAAEE,eAAe,CAAC,CAAC,GAAGY;IACrD;IAEA,IAAIpE,sBAAsBlB,cAAc;QACtC,MAAMuF,mBAAmB,CAAC,EAAE9E,cAAc,QAAQ,CAAC;QACnD,MAAMI,UAA2C;YAC/C6C,IAAIC,IAAAA,cAAM,EAAC,MAAMC,UAAU;YAC3B4B,QAAQC,IAAAA,eAAO,EAAC;YAChBd,OAAOC,IAAAA,eAAO,EAAC,SAASlC,OAAO;YAC/BmC,QAAQZ,oCAAiB,CAAClC,UAAU,CAAC,aAClCmC,UAAU,CAAC,IAAMtB,MAAMc,EAAE,EAAE;gBAAES,UAAU;YAAU,GACjDzB,OAAO;YACVoC,MAAMC,IAAAA,eAAO,EAAC,QAAQrC,OAAO;QAC/B;QAEA,IAAItB,6BAA6B;YAC/BP,QAAQoE,MAAM,GAAGpF,QAAQiE,KAAK,CAACC,aAAa,CAAC;QAC/C;QAEAtC,eAAe5B,QAAQgD,QAAQ,CAACD,KAAK,CAAC2C,kBAAkB1E,SAAS,CAACiC;YAChE,MAAMhC,UAAwC;gBAC5CoE,gBAAgBC,IAAAA,aAAK,EAAC,CAAC,EAAEI,iBAAiB,iBAAiB,CAAC,EAAEjB,EAAE,CAACxB,KAAK6B,KAAK,EAAE7B,KAAK+B,MAAM;YAC1F;YAEA,IAAI3D,uBAAuB,SAAS;gBAClCJ,QAAQ4E,SAAS,GAAGP,IAAAA,aAAK,EAAC,CAAC,EAAEI,iBAAiB,WAAW,CAAC,EAAEjB,EAAE,CAACxB,KAAK0C,MAAM;YAC5E;YAEA,IAAIpE,6BAA6B;gBAC/BN,QAAQuE,YAAY,GAAGF,IAAAA,aAAK,EAAC,CAAC,EAAEI,iBAAiB,cAAc,CAAC,EAAEjB,EAAE,CAClExB,KAAKmC,MAAM,EACXnC,KAAK+B,MAAM;YAEf;YAEA,OAAO/D;QACT;QAEAjB,QAAQ2D,MAAM,CAAC+B,iBAAiB,GAAG9D;QAEnC,MAAMkE,wBAAwBnB,IAAAA,qBAAS,EAAC/C,cAAc,CAAC,EAAEgD,GAAG,EAAE,GAAM,CAAA;gBAClEI,QAAQJ,IAAI7B,OAAO;oBACjBvC,QAAQ;wBAACoB,aAAaoD,MAAM;qBAAC;oBAC7BX,YAAY;wBAACtB,MAAMc,EAAE;qBAAC;gBACxB;YACF,CAAA;QAEA7D,QAAQ2E,SAAS,CAAC,CAAC,UAAU,EAAEe,iBAAiB,CAAC,CAAC,GAAGI;IACvD;IAEA,IAAI1F,oBAAoB;QACtB,IAAIyB,cAAckE,IAAI,EAAE;YACtB,MAAMC,sBAAuD;gBAC3DnC,IAAIC,IAAAA,cAAM,EAAC,MAAMC,UAAU;gBAC3Be,OAAOC,IAAAA,eAAO,EAAC;gBACfC,QAAQZ,oCAAiB,CAAClC,UAAU,CAAC,aAClCmC,UAAU,CAAC,IAAMtB,MAAMc,EAAE,EAAE;oBAAES,UAAU;gBAAU,GACjDzB,OAAO;gBACVoC,MAAMC,IAAAA,eAAO,EAAC,QAAQrC,OAAO;YAC/B;YAEA,IAAI1B,+BAA+B;gBACjC6E,oBAAoBZ,MAAM,GAAGpF,QAAQiE,KAAK,CAACC,aAAa,CAAC;YAC3D;YAEArC,cAAcoE,OAAO,CAAC,CAACC;gBACrB,MAAMC,sBAAsBC,IAAAA,oBAAW,EAACF;gBACxC,IAAIG,UAAUrG,QAAQsG,MAAM,KAAK,SAAS,SAAS;gBACnD,MAAMC,4BAA4BvG,QAAQwG,OAAO,CAACC,WAAW,CAC3DP,WACD,CAAC5C,MAAM,CAAC9C,MAAM,CAACkG,IAAI,CAAC,CAACC,QAAUC,IAAAA,uBAAgB,EAACD,UAAUA,MAAME,IAAI,KAAK;gBAC1E,IAAIN,2BAA2BO,SAAS,UAAUT,UAAU;gBAC5D,IAAIE,2BAA2BO,SAAS,QAAQT,UAAU;gBAE1DL,mBAAmB,CAAC,CAAC,EAAEE,WAAW,EAAE,CAAC,CAAC,GAAG9B,oCAAiB,CAACiC,QAAQ,CACjE,CAAC,EAAEF,oBAAoB,GAAG,CAAC,EAC3B9B,UAAU,CAAC,IAAMrE,QAAQ2D,MAAM,CAACwC,oBAAoB,CAACtC,EAAE,EAAE;oBAAES,UAAU;gBAAU;YACnF;YAEA,MAAMyC,yBAAyB,CAAC,EAAEjG,UAAU,KAAK,CAAC;YAElDiB,qBAAqB/B,QAAQgD,QAAQ,CAACD,KAAK,CACzCgE,wBACAf,qBACA,CAAC/C;gBACC,MAAM+D,SAAkC;oBACtClC,OAAOQ,IAAAA,aAAK,EAAC,CAAC,EAAEyB,uBAAuB,UAAU,CAAC,EAAEtC,EAAE,CAACxB,KAAK6B,KAAK;oBACjEmC,WAAW3B,IAAAA,aAAK,EAAC,CAAC,EAAEyB,uBAAuB,WAAW,CAAC,EAAEtC,EAAE,CAACxB,KAAK+B,MAAM;oBACvEkC,SAAS5B,IAAAA,aAAK,EAAC,CAAC,EAAEyB,uBAAuB,SAAS,CAAC,EAAEtC,EAAE,CAACxB,KAAKgC,IAAI;gBACnE;gBAEA,IAAI9D,+BAA+B;oBACjC6F,OAAOG,SAAS,GAAG7B,IAAAA,aAAK,EAAC,CAAC,EAAEyB,uBAAuB,WAAW,CAAC,EAAEtC,EAAE,CAACxB,KAAKmC,MAAM;gBACjF;gBAEA,OAAO4B;YACT;YAGFhH,QAAQ2D,MAAM,CAACoD,uBAAuB,GAAGhF;YAEzC,MAAMqF,8BAA8BzC,IAAAA,qBAAS,EAAC5C,oBAAoB,CAAC,EAAE6C,GAAG,EAAE;gBACxE,MAAMoC,SAA2C;oBAC/ChC,QAAQJ,IAAI7B,OAAO;wBACjBvC,QAAQ;4BAACuB,mBAAmBiD,MAAM;yBAAC;wBACnCX,YAAY;4BAACtB,MAAMc,EAAE;yBAAC;wBACtBwD,cAAc;oBAChB;gBACF;gBAEAxF,cAAcoE,OAAO,CAAC,CAACC;oBACrB,MAAMoB,mBAAmBlB,IAAAA,oBAAW,EAACF;oBACrC,MAAMqB,eAAe,CAAC,EAAErB,WAAW,EAAE,CAAC;oBACtCc,MAAM,CAACO,aAAa,GAAG3C,IAAI5E,QAAQ2D,MAAM,CAAC2D,iBAAiB,EAAE;wBAC3D9G,QAAQ;4BAACuB,kBAAkB,CAACwF,aAAa;yBAAC;wBAC1ClD,YAAY;4BAACrE,QAAQ2D,MAAM,CAAC2D,iBAAiB,CAACzD,EAAE;yBAAC;oBACnD;gBACF;gBAEA,OAAOmD;YACT;YAEAhH,QAAQ2E,SAAS,CAAC,CAAC,UAAU,EAAEoC,uBAAuB,CAAC,CAAC,GAAGK;QAC7D;IACF;IAEA,MAAMI,iBAAiB7C,IAAAA,qBAAS,EAAC5B,OAAO,CAAC,EAAE0E,IAAI,EAAE;QAC/C,MAAMT,SAA2C,CAAC;QAElDhF,iBAAiBiE,OAAO,CAAC,CAACyB,KAAKnE;YAC7ByD,MAAM,CAACzD,IAAI,GAAGkE,KAAKzH,QAAQ2D,MAAM,CAAC+D,IAAI;QACxC;QAEA,IAAIxG,mBAAmB;YACrB8F,OAAOW,QAAQ,GAAGF,KAAK/F;QACzB;QAEA,IAAIN,kBAAkB;YACpB4F,OAAOY,MAAM,GAAGH,KAAK9F;QACvB;QACA,IAAIN,oBAAoB;YACtB2F,OAAOa,QAAQ,GAAGJ,KAAK7F;QACzB;QAEA,IAAIC,cAAckE,IAAI,IAAIhE,oBAAoB;YAC5CiF,OAAOc,KAAK,GAAGL,KAAK1F,oBAAoB;gBACtCsF,cAAc;YAChB;QACF;QAEA,OAAOL;IACT;IAEAhH,QAAQ2E,SAAS,CAAC,CAAC,UAAU,EAAE7D,UAAU,CAAC,CAAC,GAAG0G;IAE9C,OAAO;QAAEnG;QAAoBD;QAAkBY;IAAiB;AAClE"}
296
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type {\n  IndexBuilder,\n  PgColumnBuilder,\n  PgTableWithColumns,\n  UniqueConstraintBuilder,\n} from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport { index, integer, numeric, serial, timestamp, unique, varchar } from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\n\nimport type { GenericColumns, GenericTable, IDType, PostgresAdapter } from '../types'\n\nimport { getTableName } from './getTableName'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { setColumnID } from './setColumnID'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  buildTexts?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n  versions: boolean\n}\n\ntype Result = {\n  hasManyNumberField: 'index' | boolean\n  hasManyTextField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  buildTexts,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n  versions,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyTextField: 'index' | boolean = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyTextField = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable | PgTableWithColumns<any>\n  let textsTable: GenericTable | PgTableWithColumns<any>\n  let numbersTable: GenericTable | PgTableWithColumns<any>\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable | PgTableWithColumns<any>\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType: IDType = setColumnID({ adapter, columns, fields })\n\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    buildTexts,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n    versions,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = adapter.pgSchema.table(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}${adapter.localesSuffix}`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = adapter.pgSchema.table(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n      text: varchar('text'),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = adapter.pgSchema.table(textsTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyTextField === 'index') {\n        indexes.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        indexes.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = adapter.pgSchema.table(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index(`${numbersTableName}_locale_parent`).on(\n          cols.locale,\n          cols.parent,\n        )\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const relationshipConfig = adapter.payload.collections[relationTo].config\n        const formattedRelationTo = getTableName({\n          adapter,\n          config: relationshipConfig,\n          throwValidationError: true,\n        })\n        let colType = adapter.idType === 'uuid' ? 'uuid' : 'integer'\n        const relatedCollectionCustomID = relationshipConfig.fields.find(\n          (field) => fieldAffectsData(field) && field.name === 'id',\n        )\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`\n\n      relationshipsTable = adapter.pgSchema.table(\n        relationshipsTableName,\n        relationshipColumns,\n        (cols) => {\n          const result: Record<string, unknown> = {\n            order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n            parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n            pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n          }\n\n          if (hasLocalizedRelationshipField) {\n            result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n          }\n\n          return result\n        },\n      )\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = getTableName({\n            adapter,\n            config: adapter.payload.collections[relationTo].config,\n            throwValidationError: true,\n          })\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyNumberField, hasManyTextField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","buildTexts","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","versions","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasManyNumberField","hasLocalizedManyTextField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","setColumnID","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgSchema","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","localesSuffix","id","serial","primaryKey","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","textsTableName","order","integer","parent","path","varchar","text","locale","orderParentIdx","index","text_idx","localeParent","textsTableRelations","numbersTableName","number","numeric","numberIdx","numbersTableRelations","size","relationshipColumns","forEach","relationTo","relationshipConfig","payload","collections","formattedRelationTo","getTableName","throwValidationError","colType","idType","relatedCollectionCustomID","find","field","fieldAffectsData","name","type","relationshipsTableName","relationshipsSuffix","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import type { DBIdentifierName } from 'payload/database';
2
+ import type { PostgresAdapter } from '../types';
3
+ type Args = {
4
+ adapter: PostgresAdapter;
5
+ /** The collection, global or field config **/
6
+ config: {
7
+ dbName?: DBIdentifierName;
8
+ enumName?: DBIdentifierName;
9
+ name?: string;
10
+ slug?: string;
11
+ };
12
+ /** Localized tables need to be given the locales suffix */
13
+ locales?: boolean;
14
+ /** For nested tables passed for the user custom dbName functions to handle their own iterations */
15
+ parentTableName?: string;
16
+ /** For sub tables (array for example) this needs to include the parentTableName */
17
+ prefix?: string;
18
+ /** Adds the relationships suffix */
19
+ relationships?: boolean;
20
+ /** For tables based on fields that could have both enumName and dbName (ie: select with hasMany), default: 'dbName' */
21
+ target?: 'dbName' | 'enumName';
22
+ throwValidationError?: boolean;
23
+ /** Adds the versions suffix, should only be used on the base collection to duplicate suffixing */
24
+ versions?: boolean;
25
+ };
26
+ /**
27
+ * Used to name database enums and tables
28
+ * Returns the table or enum name for a given entity
29
+ */
30
+ export declare const getTableName: ({ adapter, config: { name, slug }, config, locales, parentTableName, prefix, relationships, target, throwValidationError, versions, }: Args) => string;
31
+ export {};
32
+ //# sourceMappingURL=getTableName.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTableName.d.ts","sourceRoot":"","sources":["../../src/schema/getTableName.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAKxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,8CAA8C;IAC9C,MAAM,EAAE;QACN,MAAM,CAAC,EAAE,gBAAgB,CAAA;QACzB,QAAQ,CAAC,EAAE,gBAAgB,CAAA;QAC3B,IAAI,CAAC,EAAE,MAAM,CAAA;QACb,IAAI,CAAC,EAAE,MAAM,CAAA;KACd,CAAA;IACD,2DAA2D;IAC3D,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,mGAAmG;IACnG,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,mFAAmF;IACnF,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,oCAAoC;IACpC,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,uHAAuH;IACvH,MAAM,CAAC,EAAE,QAAQ,GAAG,UAAU,CAAA;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,kGAAkG;IAClG,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,YAAY,0IAWtB,IAAI,KAAG,MA4BT,CAAA"}
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "getTableName", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return getTableName;
9
+ }
10
+ });
11
+ const _errors = require("payload/errors");
12
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ const getTableName = ({ adapter, config: { name, slug }, config, locales = false, parentTableName, prefix = '', relationships = false, target = 'dbName', throwValidationError = false, versions = false })=>{
19
+ let result;
20
+ let custom = config[target];
21
+ if (!custom && target === 'enumName') {
22
+ custom = config['dbName'];
23
+ }
24
+ if (custom) {
25
+ result = typeof custom === 'function' ? custom({
26
+ tableName: parentTableName
27
+ }) : custom;
28
+ } else {
29
+ result = `${prefix}${(0, _tosnakecase.default)(name ?? slug)}`;
30
+ }
31
+ if (locales) result = `${result}${adapter.localesSuffix}`;
32
+ if (versions) result = `_${result}${adapter.versionsSuffix}`;
33
+ if (relationships) result = `${result}${adapter.relationshipsSuffix}`;
34
+ if (!throwValidationError) {
35
+ return result;
36
+ }
37
+ if (result.length > 63) {
38
+ throw new _errors.APIError(`Exceeded max identifier length for table or enum name of 63 characters. Invalid name: ${result}`);
39
+ }
40
+ return result;
41
+ };
42
+
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvZ2V0VGFibGVOYW1lLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgREJJZGVudGlmaWVyTmFtZSB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmltcG9ydCB7IEFQSUVycm9yIH0gZnJvbSAncGF5bG9hZC9lcnJvcnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuLi90eXBlcydcblxudHlwZSBBcmdzID0ge1xuICBhZGFwdGVyOiBQb3N0Z3Jlc0FkYXB0ZXJcbiAgLyoqIFRoZSBjb2xsZWN0aW9uLCBnbG9iYWwgb3IgZmllbGQgY29uZmlnICoqL1xuICBjb25maWc6IHtcbiAgICBkYk5hbWU/OiBEQklkZW50aWZpZXJOYW1lXG4gICAgZW51bU5hbWU/OiBEQklkZW50aWZpZXJOYW1lXG4gICAgbmFtZT86IHN0cmluZ1xuICAgIHNsdWc/OiBzdHJpbmdcbiAgfVxuICAvKiogTG9jYWxpemVkIHRhYmxlcyBuZWVkIHRvIGJlIGdpdmVuIHRoZSBsb2NhbGVzIHN1ZmZpeCAqL1xuICBsb2NhbGVzPzogYm9vbGVhblxuICAvKiogRm9yIG5lc3RlZCB0YWJsZXMgcGFzc2VkIGZvciB0aGUgdXNlciBjdXN0b20gZGJOYW1lIGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlaXIgb3duIGl0ZXJhdGlvbnMgKi9cbiAgcGFyZW50VGFibGVOYW1lPzogc3RyaW5nXG4gIC8qKiBGb3Igc3ViIHRhYmxlcyAoYXJyYXkgZm9yIGV4YW1wbGUpIHRoaXMgbmVlZHMgdG8gaW5jbHVkZSB0aGUgcGFyZW50VGFibGVOYW1lICovXG4gIHByZWZpeD86IHN0cmluZ1xuICAvKiogQWRkcyB0aGUgcmVsYXRpb25zaGlwcyBzdWZmaXggKi9cbiAgcmVsYXRpb25zaGlwcz86IGJvb2xlYW5cbiAgLyoqIEZvciB0YWJsZXMgYmFzZWQgb24gZmllbGRzIHRoYXQgY291bGQgaGF2ZSBib3RoIGVudW1OYW1lIGFuZCBkYk5hbWUgKGllOiBzZWxlY3Qgd2l0aCBoYXNNYW55KSwgZGVmYXVsdDogJ2RiTmFtZScgKi9cbiAgdGFyZ2V0PzogJ2RiTmFtZScgfCAnZW51bU5hbWUnXG4gIHRocm93VmFsaWRhdGlvbkVycm9yPzogYm9vbGVhblxuICAvKiogQWRkcyB0aGUgdmVyc2lvbnMgc3VmZml4LCBzaG91bGQgb25seSBiZSB1c2VkIG9uIHRoZSBiYXNlIGNvbGxlY3Rpb24gdG8gZHVwbGljYXRlIHN1ZmZpeGluZyAqL1xuICB2ZXJzaW9ucz86IGJvb2xlYW5cbn1cblxuLyoqXG4gKiBVc2VkIHRvIG5hbWUgZGF0YWJhc2UgZW51bXMgYW5kIHRhYmxlc1xuICogUmV0dXJucyB0aGUgdGFibGUgb3IgZW51bSBuYW1lIGZvciBhIGdpdmVuIGVudGl0eVxuICovXG5leHBvcnQgY29uc3QgZ2V0VGFibGVOYW1lID0gKHtcbiAgYWRhcHRlcixcbiAgY29uZmlnOiB7IG5hbWUsIHNsdWcgfSxcbiAgY29uZmlnLFxuICBsb2NhbGVzID0gZmFsc2UsXG4gIHBhcmVudFRhYmxlTmFtZSxcbiAgcHJlZml4ID0gJycsXG4gIHJlbGF0aW9uc2hpcHMgPSBmYWxzZSxcbiAgdGFyZ2V0ID0gJ2RiTmFtZScsXG4gIHRocm93VmFsaWRhdGlvbkVycm9yID0gZmFsc2UsXG4gIHZlcnNpb25zID0gZmFsc2UsXG59OiBBcmdzKTogc3RyaW5nID0+IHtcbiAgbGV0IHJlc3VsdDogc3RyaW5nXG4gIGxldCBjdXN0b20gPSBjb25maWdbdGFyZ2V0XVxuXG4gIGlmICghY3VzdG9tICYmIHRhcmdldCA9PT0gJ2VudW1OYW1lJykge1xuICAgIGN1c3RvbSA9IGNvbmZpZ1snZGJOYW1lJ11cbiAgfVxuXG4gIGlmIChjdXN0b20pIHtcbiAgICByZXN1bHQgPSB0eXBlb2YgY3VzdG9tID09PSAnZnVuY3Rpb24nID8gY3VzdG9tKHsgdGFibGVOYW1lOiBwYXJlbnRUYWJsZU5hbWUgfSkgOiBjdXN0b21cbiAgfSBlbHNlIHtcbiAgICByZXN1bHQgPSBgJHtwcmVmaXh9JHt0b1NuYWtlQ2FzZShuYW1lID8/IHNsdWcpfWBcbiAgfVxuXG4gIGlmIChsb2NhbGVzKSByZXN1bHQgPSBgJHtyZXN1bHR9JHthZGFwdGVyLmxvY2FsZXNTdWZmaXh9YFxuICBpZiAodmVyc2lvbnMpIHJlc3VsdCA9IGBfJHtyZXN1bHR9JHthZGFwdGVyLnZlcnNpb25zU3VmZml4fWBcbiAgaWYgKHJlbGF0aW9uc2hpcHMpIHJlc3VsdCA9IGAke3Jlc3VsdH0ke2FkYXB0ZXIucmVsYXRpb25zaGlwc1N1ZmZpeH1gXG5cbiAgaWYgKCF0aHJvd1ZhbGlkYXRpb25FcnJvcikge1xuICAgIHJldHVybiByZXN1bHRcbiAgfVxuXG4gIGlmIChyZXN1bHQubGVuZ3RoID4gNjMpIHtcbiAgICB0aHJvdyBuZXcgQVBJRXJyb3IoXG4gICAgICBgRXhjZWVkZWQgbWF4IGlkZW50aWZpZXIgbGVuZ3RoIGZvciB0YWJsZSBvciBlbnVtIG5hbWUgb2YgNjMgY2hhcmFjdGVycy4gSW52YWxpZCBuYW1lOiAke3Jlc3VsdH1gLFxuICAgIClcbiAgfVxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsiZ2V0VGFibGVOYW1lIiwiYWRhcHRlciIsImNvbmZpZyIsIm5hbWUiLCJzbHVnIiwibG9jYWxlcyIsInBhcmVudFRhYmxlTmFtZSIsInByZWZpeCIsInJlbGF0aW9uc2hpcHMiLCJ0YXJnZXQiLCJ0aHJvd1ZhbGlkYXRpb25FcnJvciIsInZlcnNpb25zIiwicmVzdWx0IiwiY3VzdG9tIiwidGFibGVOYW1lIiwidG9TbmFrZUNhc2UiLCJsb2NhbGVzU3VmZml4IiwidmVyc2lvbnNTdWZmaXgiLCJyZWxhdGlvbnNoaXBzU3VmZml4IiwibGVuZ3RoIiwiQVBJRXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7K0JBbUNhQTs7O2VBQUFBOzs7d0JBakNZO29FQUNEOzs7Ozs7QUFnQ2pCLE1BQU1BLGVBQWUsQ0FBQyxFQUMzQkMsT0FBTyxFQUNQQyxRQUFRLEVBQUVDLElBQUksRUFBRUMsSUFBSSxFQUFFLEVBQ3RCRixNQUFNLEVBQ05HLFVBQVUsS0FBSyxFQUNmQyxlQUFlLEVBQ2ZDLFNBQVMsRUFBRSxFQUNYQyxnQkFBZ0IsS0FBSyxFQUNyQkMsU0FBUyxRQUFRLEVBQ2pCQyx1QkFBdUIsS0FBSyxFQUM1QkMsV0FBVyxLQUFLLEVBQ1g7SUFDTCxJQUFJQztJQUNKLElBQUlDLFNBQVNYLE1BQU0sQ0FBQ08sT0FBTztJQUUzQixJQUFJLENBQUNJLFVBQVVKLFdBQVcsWUFBWTtRQUNwQ0ksU0FBU1gsTUFBTSxDQUFDLFNBQVM7SUFDM0I7SUFFQSxJQUFJVyxRQUFRO1FBQ1ZELFNBQVMsT0FBT0MsV0FBVyxhQUFhQSxPQUFPO1lBQUVDLFdBQVdSO1FBQWdCLEtBQUtPO0lBQ25GLE9BQU87UUFDTEQsU0FBUyxDQUFDLEVBQUVMLE9BQU8sRUFBRVEsSUFBQUEsb0JBQVcsRUFBQ1osUUFBUUMsTUFBTSxDQUFDO0lBQ2xEO0lBRUEsSUFBSUMsU0FBU08sU0FBUyxDQUFDLEVBQUVBLE9BQU8sRUFBRVgsUUFBUWUsYUFBYSxDQUFDLENBQUM7SUFDekQsSUFBSUwsVUFBVUMsU0FBUyxDQUFDLENBQUMsRUFBRUEsT0FBTyxFQUFFWCxRQUFRZ0IsY0FBYyxDQUFDLENBQUM7SUFDNUQsSUFBSVQsZUFBZUksU0FBUyxDQUFDLEVBQUVBLE9BQU8sRUFBRVgsUUFBUWlCLG1CQUFtQixDQUFDLENBQUM7SUFFckUsSUFBSSxDQUFDUixzQkFBc0I7UUFDekIsT0FBT0U7SUFDVDtJQUVBLElBQUlBLE9BQU9PLE1BQU0sR0FBRyxJQUFJO1FBQ3RCLE1BQU0sSUFBSUMsZ0JBQVEsQ0FDaEIsQ0FBQyxzRkFBc0YsRUFBRVIsT0FBTyxDQUFDO0lBRXJHO0lBQ0EsT0FBT0E7QUFDVCJ9
@@ -23,6 +23,7 @@ type Args = {
23
23
  rootRelationsToBuild?: Map<string, string>;
24
24
  rootTableIDColType: string;
25
25
  rootTableName: string;
26
+ versions: boolean;
26
27
  };
27
28
  type Result = {
28
29
  hasLocalizedField: boolean;
@@ -32,6 +33,6 @@ type Result = {
32
33
  hasManyNumberField: 'index' | boolean;
33
34
  hasManyTextField: 'index' | boolean;
34
35
  };
35
- export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, buildTexts, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, }: Args) => Result;
36
+ export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, buildTexts, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, versions, }: Args) => Result;
36
37
  export {};
37
38
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAqBtD,OAAO,KAAK,EAAE,cAAc,EAAU,eAAe,EAAE,MAAM,UAAU,CAAA;AASvE,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,4TAsBxB,IAAI,KAAG,MA6kBT,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAqBtD,OAAO,KAAK,EAAE,cAAc,EAAU,eAAe,EAAE,MAAM,UAAU,CAAA;AAUvE,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;IACrB,QAAQ,EAAE,OAAO,CAAA;CAClB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,sUAuBxB,IAAI,KAAG,MAinBT,CAAA"}