@payloadcms/db-mongodb 1.5.2 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/dist/count.js +2 -2
  2. package/dist/create.d.ts.map +1 -1
  3. package/dist/create.js +5 -7
  4. package/dist/createGlobal.d.ts.map +1 -1
  5. package/dist/createGlobal.js +3 -5
  6. package/dist/createGlobalVersion.d.ts.map +1 -1
  7. package/dist/createGlobalVersion.js +10 -6
  8. package/dist/createVersion.js +10 -6
  9. package/dist/deleteMany.js +2 -2
  10. package/dist/deleteOne.d.ts.map +1 -1
  11. package/dist/deleteOne.js +5 -8
  12. package/dist/deleteVersions.js +2 -2
  13. package/dist/find.d.ts.map +1 -1
  14. package/dist/find.js +9 -5
  15. package/dist/findGlobal.d.ts.map +1 -1
  16. package/dist/findGlobal.js +6 -4
  17. package/dist/findGlobalVersions.d.ts.map +1 -1
  18. package/dist/findGlobalVersions.js +9 -5
  19. package/dist/findOne.d.ts.map +1 -1
  20. package/dist/findOne.js +6 -8
  21. package/dist/findVersions.d.ts.map +1 -1
  22. package/dist/findVersions.js +9 -5
  23. package/dist/index.d.ts +42 -3
  24. package/dist/index.d.ts.map +1 -1
  25. package/dist/index.js +6 -2
  26. package/dist/init.d.ts.map +1 -1
  27. package/dist/init.js +11 -7
  28. package/dist/models/buildCollectionSchema.d.ts +2 -2
  29. package/dist/models/buildCollectionSchema.d.ts.map +1 -1
  30. package/dist/models/buildCollectionSchema.js +7 -6
  31. package/dist/models/buildGlobalModel.d.ts +2 -2
  32. package/dist/models/buildGlobalModel.d.ts.map +1 -1
  33. package/dist/models/buildGlobalModel.js +10 -6
  34. package/dist/models/buildSchema.d.ts +2 -2
  35. package/dist/models/buildSchema.d.ts.map +1 -1
  36. package/dist/models/buildSchema.js +72 -62
  37. package/dist/queryDrafts.d.ts.map +1 -1
  38. package/dist/queryDrafts.js +9 -3
  39. package/dist/transactions/commitTransaction.d.ts.map +1 -1
  40. package/dist/transactions/commitTransaction.js +2 -1
  41. package/dist/transactions/rollbackTransaction.d.ts.map +1 -1
  42. package/dist/transactions/rollbackTransaction.js +14 -8
  43. package/dist/updateGlobal.d.ts.map +1 -1
  44. package/dist/updateGlobal.js +3 -5
  45. package/dist/updateGlobalVersion.d.ts.map +1 -1
  46. package/dist/updateGlobalVersion.js +12 -8
  47. package/dist/updateOne.d.ts.map +1 -1
  48. package/dist/updateOne.js +4 -6
  49. package/dist/updateVersion.d.ts.map +1 -1
  50. package/dist/updateVersion.js +12 -8
  51. package/dist/utilities/sanitizeInternalFields.d.ts.map +1 -1
  52. package/dist/utilities/sanitizeInternalFields.js +7 -4
  53. package/dist/withSession.d.ts +3 -2
  54. package/dist/withSession.d.ts.map +1 -1
  55. package/dist/withSession.js +7 -3
  56. package/package.json +3 -3
@@ -28,10 +28,10 @@ const formatBaseSchema = (field, buildSchemaOptions)=>{
28
28
  const localizeSchema = (entity, schema, localization)=>{
29
29
  if ((0, _types.fieldIsLocalized)(entity) && localization && Array.isArray(localization.locales)) {
30
30
  return {
31
- type: localization.localeCodes.reduce((localeSchema, locale)=>({
32
- ...localeSchema,
33
- [locale]: schema
34
- }), {
31
+ type: localization.localeCodes.reduce((localeSchema, locale)=>{
32
+ localeSchema[locale] = schema;
33
+ return localeSchema;
34
+ }, {
35
35
  _id: false
36
36
  }),
37
37
  localized: true
@@ -39,7 +39,7 @@ const localizeSchema = (entity, schema, localization)=>{
39
39
  }
40
40
  return schema;
41
41
  };
42
- const buildSchema = (config, configFields, buildSchemaOptions = {})=>{
42
+ const buildSchema = (adapter, configFields, buildSchemaOptions = {})=>{
43
43
  const { allowIDField, options } = buildSchemaOptions;
44
44
  let fields = {};
45
45
  let schemaFields = configFields;
@@ -57,60 +57,66 @@ const buildSchema = (config, configFields, buildSchemaOptions = {})=>{
57
57
  if (!(0, _types.fieldIsPresentationalOnly)(field)) {
58
58
  const addFieldSchema = fieldToSchemaMap[field.type];
59
59
  if (addFieldSchema) {
60
- addFieldSchema(field, schema, config, buildSchemaOptions);
60
+ addFieldSchema(field, schema, adapter, buildSchemaOptions);
61
61
  }
62
62
  }
63
63
  });
64
64
  return schema;
65
65
  };
66
66
  const fieldToSchemaMap = {
67
- array: (field, schema, config, buildSchemaOptions)=>{
67
+ array: (field, schema, adapter, buildSchemaOptions)=>{
68
68
  const baseSchema = {
69
69
  ...formatBaseSchema(field, buildSchemaOptions),
70
70
  type: [
71
- buildSchema(config, field.fields, {
71
+ buildSchema(adapter, field.fields, {
72
72
  allowIDField: true,
73
73
  disableUnique: buildSchemaOptions.disableUnique,
74
74
  draftsEnabled: buildSchemaOptions.draftsEnabled,
75
75
  options: {
76
+ minimize: false,
77
+ ...buildSchemaOptions.options || {},
76
78
  _id: false,
77
79
  id: false,
78
- minimize: false
80
+ timestamps: false
79
81
  }
80
82
  })
81
83
  ],
82
84
  default: undefined
83
85
  };
84
86
  schema.add({
85
- [field.name]: localizeSchema(field, baseSchema, config.localization)
87
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
86
88
  });
87
89
  },
88
- blocks: (field, schema, config, buildSchemaOptions)=>{
90
+ blocks: (field, schema, adapter, buildSchemaOptions)=>{
89
91
  const fieldSchema = {
90
92
  type: [
91
93
  new _mongoose.Schema({}, {
92
94
  _id: false,
93
- discriminatorKey: 'blockType'
95
+ discriminatorKey: 'blockType',
96
+ ...buildSchemaOptions.options || {},
97
+ timestamps: false
94
98
  })
95
99
  ],
96
100
  default: undefined
97
101
  };
98
102
  schema.add({
99
- [field.name]: localizeSchema(field, fieldSchema, config.localization)
103
+ [field.name]: localizeSchema(field, fieldSchema, adapter.payload.config.localization)
100
104
  });
101
105
  field.blocks.forEach((blockItem)=>{
102
106
  const blockSchema = new _mongoose.Schema({}, {
107
+ ...buildSchemaOptions.options || {},
103
108
  _id: false,
104
- id: false
109
+ id: false,
110
+ timestamps: false
105
111
  });
106
112
  blockItem.fields.forEach((blockField)=>{
107
113
  const addFieldSchema = fieldToSchemaMap[blockField.type];
108
114
  if (addFieldSchema) {
109
- addFieldSchema(blockField, blockSchema, config, buildSchemaOptions);
115
+ addFieldSchema(blockField, blockSchema, adapter, buildSchemaOptions);
110
116
  }
111
117
  });
112
- if (field.localized && config.localization) {
113
- config.localization.localeCodes.forEach((localeCode)=>{
118
+ if (field.localized && adapter.payload.config.localization) {
119
+ adapter.payload.config.localization.localeCodes.forEach((localeCode)=>{
114
120
  // eslint-disable-next-line @typescript-eslint/ban-ts-comment
115
121
  // @ts-expect-error Possible incorrect typing in mongoose types, this works
116
122
  schema.path(`${field.name}.${localeCode}`).discriminator(blockItem.slug, blockSchema);
@@ -122,81 +128,83 @@ const fieldToSchemaMap = {
122
128
  }
123
129
  });
124
130
  },
125
- checkbox: (field, schema, config, buildSchemaOptions)=>{
131
+ checkbox: (field, schema, adapter, buildSchemaOptions)=>{
126
132
  const baseSchema = {
127
133
  ...formatBaseSchema(field, buildSchemaOptions),
128
134
  type: Boolean
129
135
  };
130
136
  schema.add({
131
- [field.name]: localizeSchema(field, baseSchema, config.localization)
137
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
132
138
  });
133
139
  },
134
- code: (field, schema, config, buildSchemaOptions)=>{
140
+ code: (field, schema, adapter, buildSchemaOptions)=>{
135
141
  const baseSchema = {
136
142
  ...formatBaseSchema(field, buildSchemaOptions),
137
143
  type: String
138
144
  };
139
145
  schema.add({
140
- [field.name]: localizeSchema(field, baseSchema, config.localization)
146
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
141
147
  });
142
148
  },
143
- collapsible: (field, schema, config, buildSchemaOptions)=>{
149
+ collapsible: (field, schema, adapter, buildSchemaOptions)=>{
144
150
  field.fields.forEach((subField)=>{
145
151
  const addFieldSchema = fieldToSchemaMap[subField.type];
146
152
  if (addFieldSchema) {
147
- addFieldSchema(subField, schema, config, buildSchemaOptions);
153
+ addFieldSchema(subField, schema, adapter, buildSchemaOptions);
148
154
  }
149
155
  });
150
156
  },
151
- date: (field, schema, config, buildSchemaOptions)=>{
157
+ date: (field, schema, adapter, buildSchemaOptions)=>{
152
158
  const baseSchema = {
153
159
  ...formatBaseSchema(field, buildSchemaOptions),
154
160
  type: Date
155
161
  };
156
162
  schema.add({
157
- [field.name]: localizeSchema(field, baseSchema, config.localization)
163
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
158
164
  });
159
165
  },
160
- email: (field, schema, config, buildSchemaOptions)=>{
166
+ email: (field, schema, adapter, buildSchemaOptions)=>{
161
167
  const baseSchema = {
162
168
  ...formatBaseSchema(field, buildSchemaOptions),
163
169
  type: String
164
170
  };
165
171
  schema.add({
166
- [field.name]: localizeSchema(field, baseSchema, config.localization)
172
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
167
173
  });
168
174
  },
169
- group: (field, schema, config, buildSchemaOptions)=>{
175
+ group: (field, schema, adapter, buildSchemaOptions)=>{
170
176
  const formattedBaseSchema = formatBaseSchema(field, buildSchemaOptions);
171
177
  // carry indexSortableFields through to versions if drafts enabled
172
178
  const indexSortableFields = buildSchemaOptions.indexSortableFields && field.name === 'version' && buildSchemaOptions.draftsEnabled;
173
179
  const baseSchema = {
174
180
  ...formattedBaseSchema,
175
- type: buildSchema(config, field.fields, {
181
+ type: buildSchema(adapter, field.fields, {
176
182
  disableUnique: buildSchemaOptions.disableUnique,
177
183
  draftsEnabled: buildSchemaOptions.draftsEnabled,
178
184
  indexSortableFields,
179
185
  options: {
186
+ minimize: false,
187
+ ...buildSchemaOptions.options || {},
180
188
  _id: false,
181
189
  id: false,
182
- minimize: false
190
+ timestamps: false
183
191
  }
184
192
  })
185
193
  };
186
194
  schema.add({
187
- [field.name]: localizeSchema(field, baseSchema, config.localization)
195
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
188
196
  });
189
197
  },
190
- json: (field, schema, config, buildSchemaOptions)=>{
198
+ json: (field, schema, adapter, buildSchemaOptions)=>{
191
199
  const baseSchema = {
192
200
  ...formatBaseSchema(field, buildSchemaOptions),
193
201
  type: _mongoose.Schema.Types.Mixed
194
202
  };
195
203
  schema.add({
196
- [field.name]: localizeSchema(field, baseSchema, config.localization)
204
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
197
205
  });
198
206
  },
199
- number: (field, schema, config, buildSchemaOptions)=>{
207
+ number: (field, schema, adapter, buildSchemaOptions)=>{
200
208
  const baseSchema = {
201
209
  ...formatBaseSchema(field, buildSchemaOptions),
202
210
  type: field.hasMany ? [
@@ -204,10 +212,10 @@ const fieldToSchemaMap = {
204
212
  ] : Number
205
213
  };
206
214
  schema.add({
207
- [field.name]: localizeSchema(field, baseSchema, config.localization)
215
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
208
216
  });
209
217
  },
210
- point: (field, schema, config, buildSchemaOptions)=>{
218
+ point: (field, schema, adapter, buildSchemaOptions)=>{
211
219
  const baseSchema = {
212
220
  type: {
213
221
  type: String,
@@ -227,7 +235,7 @@ const fieldToSchemaMap = {
227
235
  baseSchema.coordinates.sparse = true;
228
236
  }
229
237
  schema.add({
230
- [field.name]: localizeSchema(field, baseSchema, config.localization)
238
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
231
239
  });
232
240
  if (field.index === true || field.index === undefined) {
233
241
  const indexOptions = {};
@@ -235,8 +243,8 @@ const fieldToSchemaMap = {
235
243
  indexOptions.sparse = true;
236
244
  indexOptions.unique = true;
237
245
  }
238
- if (field.localized && config.localization) {
239
- config.localization.locales.forEach((locale)=>{
246
+ if (field.localized && adapter.payload.config.localization) {
247
+ adapter.payload.config.localization.locales.forEach((locale)=>{
240
248
  schema.index({
241
249
  [`${field.name}.${locale.code}`]: '2dsphere'
242
250
  }, indexOptions);
@@ -248,7 +256,7 @@ const fieldToSchemaMap = {
248
256
  }
249
257
  }
250
258
  },
251
- radio: (field, schema, config, buildSchemaOptions)=>{
259
+ radio: (field, schema, adapter, buildSchemaOptions)=>{
252
260
  const baseSchema = {
253
261
  ...formatBaseSchema(field, buildSchemaOptions),
254
262
  type: String,
@@ -258,15 +266,15 @@ const fieldToSchemaMap = {
258
266
  })
259
267
  };
260
268
  schema.add({
261
- [field.name]: localizeSchema(field, baseSchema, config.localization)
269
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
262
270
  });
263
271
  },
264
- relationship: (field, schema, config, buildSchemaOptions)=>{
272
+ relationship: (field, schema, adapter, buildSchemaOptions)=>{
265
273
  const hasManyRelations = Array.isArray(field.relationTo);
266
274
  let schemaToReturn = {};
267
- if (field.localized && config.localization) {
275
+ if (field.localized && adapter.payload.config.localization) {
268
276
  schemaToReturn = {
269
- type: config.localization.localeCodes.reduce((locales, locale)=>{
277
+ type: adapter.payload.config.localization.localeCodes.reduce((locales, locale)=>{
270
278
  let localeSchema = {};
271
279
  if (hasManyRelations) {
272
280
  localeSchema = {
@@ -342,24 +350,24 @@ const fieldToSchemaMap = {
342
350
  [field.name]: schemaToReturn
343
351
  });
344
352
  },
345
- richText: (field, schema, config, buildSchemaOptions)=>{
353
+ richText: (field, schema, adapter, buildSchemaOptions)=>{
346
354
  const baseSchema = {
347
355
  ...formatBaseSchema(field, buildSchemaOptions),
348
356
  type: _mongoose.Schema.Types.Mixed
349
357
  };
350
358
  schema.add({
351
- [field.name]: localizeSchema(field, baseSchema, config.localization)
359
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
352
360
  });
353
361
  },
354
- row: (field, schema, config, buildSchemaOptions)=>{
362
+ row: (field, schema, adapter, buildSchemaOptions)=>{
355
363
  field.fields.forEach((subField)=>{
356
364
  const addFieldSchema = fieldToSchemaMap[subField.type];
357
365
  if (addFieldSchema) {
358
- addFieldSchema(subField, schema, config, buildSchemaOptions);
366
+ addFieldSchema(subField, schema, adapter, buildSchemaOptions);
359
367
  }
360
368
  });
361
369
  },
362
- select: (field, schema, config, buildSchemaOptions)=>{
370
+ select: (field, schema, adapter, buildSchemaOptions)=>{
363
371
  const baseSchema = {
364
372
  ...formatBaseSchema(field, buildSchemaOptions),
365
373
  type: String,
@@ -374,37 +382,39 @@ const fieldToSchemaMap = {
374
382
  schema.add({
375
383
  [field.name]: localizeSchema(field, field.hasMany ? [
376
384
  baseSchema
377
- ] : baseSchema, config.localization)
385
+ ] : baseSchema, adapter.payload.config.localization)
378
386
  });
379
387
  },
380
- tabs: (field, schema, config, buildSchemaOptions)=>{
388
+ tabs: (field, schema, adapter, buildSchemaOptions)=>{
381
389
  field.tabs.forEach((tab)=>{
382
390
  if ((0, _types.tabHasName)(tab)) {
383
391
  const baseSchema = {
384
- type: buildSchema(config, tab.fields, {
392
+ type: buildSchema(adapter, tab.fields, {
385
393
  disableUnique: buildSchemaOptions.disableUnique,
386
394
  draftsEnabled: buildSchemaOptions.draftsEnabled,
387
395
  options: {
396
+ minimize: false,
397
+ ...buildSchemaOptions.options || {},
388
398
  _id: false,
389
399
  id: false,
390
- minimize: false
400
+ timestamps: false
391
401
  }
392
402
  })
393
403
  };
394
404
  schema.add({
395
- [tab.name]: localizeSchema(tab, baseSchema, config.localization)
405
+ [tab.name]: localizeSchema(tab, baseSchema, adapter.payload.config.localization)
396
406
  });
397
407
  } else {
398
408
  tab.fields.forEach((subField)=>{
399
409
  const addFieldSchema = fieldToSchemaMap[subField.type];
400
410
  if (addFieldSchema) {
401
- addFieldSchema(subField, schema, config, buildSchemaOptions);
411
+ addFieldSchema(subField, schema, adapter, buildSchemaOptions);
402
412
  }
403
413
  });
404
414
  }
405
415
  });
406
416
  },
407
- text: (field, schema, config, buildSchemaOptions)=>{
417
+ text: (field, schema, adapter, buildSchemaOptions)=>{
408
418
  const baseSchema = {
409
419
  ...formatBaseSchema(field, buildSchemaOptions),
410
420
  type: field.hasMany ? [
@@ -412,29 +422,29 @@ const fieldToSchemaMap = {
412
422
  ] : String
413
423
  };
414
424
  schema.add({
415
- [field.name]: localizeSchema(field, baseSchema, config.localization)
425
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
416
426
  });
417
427
  },
418
- textarea: (field, schema, config, buildSchemaOptions)=>{
428
+ textarea: (field, schema, adapter, buildSchemaOptions)=>{
419
429
  const baseSchema = {
420
430
  ...formatBaseSchema(field, buildSchemaOptions),
421
431
  type: String
422
432
  };
423
433
  schema.add({
424
- [field.name]: localizeSchema(field, baseSchema, config.localization)
434
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
425
435
  });
426
436
  },
427
- upload: (field, schema, config, buildSchemaOptions)=>{
437
+ upload: (field, schema, adapter, buildSchemaOptions)=>{
428
438
  const baseSchema = {
429
439
  ...formatBaseSchema(field, buildSchemaOptions),
430
440
  type: _mongoose.Schema.Types.Mixed,
431
441
  ref: field.relationTo
432
442
  };
433
443
  schema.add({
434
- [field.name]: localizeSchema(field, baseSchema, config.localization)
444
+ [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization)
435
445
  });
436
446
  }
437
447
  };
438
448
  const _default = buildSchema;
439
449
 
440
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/models/buildSchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n/* eslint-disable class-methods-use-this */\n/* eslint-disable @typescript-eslint/no-use-before-define */\n/* eslint-disable no-use-before-define */\nimport type { IndexOptions, SchemaOptions, SchemaTypeOptions } from 'mongoose'\nimport type { SanitizedConfig, SanitizedLocalizationConfig } from 'payload/config'\nimport type {\n  ArrayField,\n  Block,\n  BlockField,\n  CheckboxField,\n  CodeField,\n  CollapsibleField,\n  DateField,\n  EmailField,\n  Field,\n  FieldAffectingData,\n  GroupField,\n  JSONField,\n  NonPresentationalField,\n  NumberField,\n  PointField,\n  RadioField,\n  RelationshipField,\n  RichTextField,\n  RowField,\n  SelectField,\n  Tab,\n  TabsField,\n  TextField,\n  TextareaField,\n  UploadField,\n} from 'payload/types'\n\nimport { Schema } from 'mongoose'\nimport {\n  fieldAffectsData,\n  fieldIsLocalized,\n  fieldIsPresentationalOnly,\n  tabHasName,\n} from 'payload/types'\n\nexport type BuildSchemaOptions = {\n  allowIDField?: boolean\n  disableUnique?: boolean\n  draftsEnabled?: boolean\n  indexSortableFields?: boolean\n  options?: SchemaOptions\n}\n\ntype FieldSchemaGenerator = (\n  field: Field,\n  schema: Schema,\n  config: SanitizedConfig,\n  buildSchemaOptions: BuildSchemaOptions,\n) => void\n\nconst formatBaseSchema = (field: FieldAffectingData, buildSchemaOptions: BuildSchemaOptions) => {\n  const { disableUnique, draftsEnabled, indexSortableFields } = buildSchemaOptions\n  const schema: SchemaTypeOptions<unknown> = {\n    index: field.index || (!disableUnique && field.unique) || indexSortableFields || false,\n    required: false,\n    unique: (!disableUnique && field.unique) || false,\n  }\n\n  if (\n    schema.unique &&\n    (field.localized ||\n      draftsEnabled ||\n      (fieldAffectsData(field) &&\n        field.type !== 'group' &&\n        field.type !== 'tab' &&\n        field.required !== true))\n  ) {\n    schema.sparse = true\n  }\n\n  if (field.hidden) {\n    schema.hidden = true\n  }\n\n  return schema\n}\n\nconst localizeSchema = (\n  entity: NonPresentationalField | Tab,\n  schema,\n  localization: SanitizedLocalizationConfig | false,\n) => {\n  if (fieldIsLocalized(entity) && localization && Array.isArray(localization.locales)) {\n    return {\n      type: localization.localeCodes.reduce(\n        (localeSchema, locale) => ({\n          ...localeSchema,\n          [locale]: schema,\n        }),\n        {\n          _id: false,\n        },\n      ),\n      localized: true,\n    }\n  }\n  return schema\n}\n\nconst buildSchema = (\n  config: SanitizedConfig,\n  configFields: Field[],\n  buildSchemaOptions: BuildSchemaOptions = {},\n): Schema => {\n  const { allowIDField, options } = buildSchemaOptions\n  let fields = {}\n\n  let schemaFields = configFields\n\n  if (!allowIDField) {\n    const idField = schemaFields.find((field) => fieldAffectsData(field) && field.name === 'id')\n    if (idField) {\n      fields = {\n        _id: idField.type === 'number' ? Number : String,\n      }\n      schemaFields = schemaFields.filter(\n        (field) => !(fieldAffectsData(field) && field.name === 'id'),\n      )\n    }\n  }\n\n  const schema = new Schema(fields, options)\n\n  schemaFields.forEach((field) => {\n    if (!fieldIsPresentationalOnly(field)) {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[field.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(field, schema, config, buildSchemaOptions)\n      }\n    }\n  })\n\n  return schema\n}\n\nconst fieldToSchemaMap: Record<string, FieldSchemaGenerator> = {\n  array: (\n    field: ArrayField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ) => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: [\n        buildSchema(config, field.fields, {\n          allowIDField: true,\n          disableUnique: buildSchemaOptions.disableUnique,\n          draftsEnabled: buildSchemaOptions.draftsEnabled,\n          options: {\n            _id: false,\n            id: false,\n            minimize: false,\n          },\n        }),\n      ],\n      default: undefined,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  blocks: (\n    field: BlockField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const fieldSchema = {\n      type: [new Schema({}, { _id: false, discriminatorKey: 'blockType' })],\n      default: undefined,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, fieldSchema, config.localization),\n    })\n\n    field.blocks.forEach((blockItem: Block) => {\n      const blockSchema = new Schema({}, { _id: false, id: false })\n\n      blockItem.fields.forEach((blockField) => {\n        const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[blockField.type]\n        if (addFieldSchema) {\n          addFieldSchema(blockField, blockSchema, config, buildSchemaOptions)\n        }\n      })\n\n      if (field.localized && config.localization) {\n        config.localization.localeCodes.forEach((localeCode) => {\n          // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n          // @ts-expect-error Possible incorrect typing in mongoose types, this works\n          schema.path(`${field.name}.${localeCode}`).discriminator(blockItem.slug, blockSchema)\n        })\n      } else {\n        // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n        // @ts-expect-error Possible incorrect typing in mongoose types, this works\n        schema.path(field.name).discriminator(blockItem.slug, blockSchema)\n      }\n    })\n  },\n  checkbox: (\n    field: CheckboxField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Boolean }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  code: (\n    field: CodeField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  collapsible: (\n    field: CollapsibleField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.fields.forEach((subField: Field) => {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(subField, schema, config, buildSchemaOptions)\n      }\n    })\n  },\n  date: (\n    field: DateField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Date }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  email: (\n    field: EmailField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  group: (\n    field: GroupField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const formattedBaseSchema = formatBaseSchema(field, buildSchemaOptions)\n\n    // carry indexSortableFields through to versions if drafts enabled\n    const indexSortableFields =\n      buildSchemaOptions.indexSortableFields &&\n      field.name === 'version' &&\n      buildSchemaOptions.draftsEnabled\n\n    const baseSchema = {\n      ...formattedBaseSchema,\n      type: buildSchema(config, field.fields, {\n        disableUnique: buildSchemaOptions.disableUnique,\n        draftsEnabled: buildSchemaOptions.draftsEnabled,\n        indexSortableFields,\n        options: {\n          _id: false,\n          id: false,\n          minimize: false,\n        },\n      }),\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  json: (\n    field: JSONField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Schema.Types.Mixed }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  number: (\n    field: NumberField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: field.hasMany ? [Number] : Number,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  point: (\n    field: PointField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema: SchemaTypeOptions<unknown> = {\n      type: {\n        type: String,\n        enum: ['Point'],\n      },\n      coordinates: {\n        type: [Number],\n        default: field.defaultValue || undefined,\n        required: false,\n      },\n    }\n    if (buildSchemaOptions.disableUnique && field.unique && field.localized) {\n      baseSchema.coordinates.sparse = true\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n\n    if (field.index === true || field.index === undefined) {\n      const indexOptions: IndexOptions = {}\n      if (!buildSchemaOptions.disableUnique && field.unique) {\n        indexOptions.sparse = true\n        indexOptions.unique = true\n      }\n      if (field.localized && config.localization) {\n        config.localization.locales.forEach((locale) => {\n          schema.index({ [`${field.name}.${locale.code}`]: '2dsphere' }, indexOptions)\n        })\n      } else {\n        schema.index({ [field.name]: '2dsphere' }, indexOptions)\n      }\n    }\n  },\n  radio: (\n    field: RadioField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: String,\n      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  relationship: (\n    field: RelationshipField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ) => {\n    const hasManyRelations = Array.isArray(field.relationTo)\n    let schemaToReturn: { [key: string]: any } = {}\n\n    if (field.localized && config.localization) {\n      schemaToReturn = {\n        type: config.localization.localeCodes.reduce((locales, locale) => {\n          let localeSchema: { [key: string]: any } = {}\n\n          if (hasManyRelations) {\n            localeSchema = {\n              ...formatBaseSchema(field, buildSchemaOptions),\n              _id: false,\n              type: Schema.Types.Mixed,\n              relationTo: { type: String, enum: field.relationTo },\n              value: {\n                type: Schema.Types.Mixed,\n                refPath: `${field.name}.${locale}.relationTo`,\n              },\n            }\n          } else {\n            localeSchema = {\n              ...formatBaseSchema(field, buildSchemaOptions),\n              type: Schema.Types.Mixed,\n              ref: field.relationTo,\n            }\n          }\n\n          return {\n            ...locales,\n            [locale]: field.hasMany ? { type: [localeSchema], default: undefined } : localeSchema,\n          }\n        }, {}),\n        localized: true,\n      }\n    } else if (hasManyRelations) {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        _id: false,\n        type: Schema.Types.Mixed,\n        relationTo: { type: String, enum: field.relationTo },\n        value: {\n          type: Schema.Types.Mixed,\n          refPath: `${field.name}.relationTo`,\n        },\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          type: [schemaToReturn],\n          default: undefined,\n        }\n      }\n    } else {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        type: Schema.Types.Mixed,\n        ref: field.relationTo,\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          type: [schemaToReturn],\n          default: undefined,\n        }\n      }\n    }\n\n    schema.add({\n      [field.name]: schemaToReturn,\n    })\n  },\n  richText: (\n    field: RichTextField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Schema.Types.Mixed }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  row: (\n    field: RowField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.fields.forEach((subField: Field) => {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(subField, schema, config, buildSchemaOptions)\n      }\n    })\n  },\n  select: (\n    field: SelectField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: String,\n      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n    }\n\n    if (buildSchemaOptions.draftsEnabled || !field.required) {\n      baseSchema.enum.push(null)\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(\n        field,\n        field.hasMany ? [baseSchema] : baseSchema,\n        config.localization,\n      ),\n    })\n  },\n  tabs: (\n    field: TabsField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.tabs.forEach((tab) => {\n      if (tabHasName(tab)) {\n        const baseSchema = {\n          type: buildSchema(config, tab.fields, {\n            disableUnique: buildSchemaOptions.disableUnique,\n            draftsEnabled: buildSchemaOptions.draftsEnabled,\n            options: {\n              _id: false,\n              id: false,\n              minimize: false,\n            },\n          }),\n        }\n\n        schema.add({\n          [tab.name]: localizeSchema(tab, baseSchema, config.localization),\n        })\n      } else {\n        tab.fields.forEach((subField: Field) => {\n          const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n          if (addFieldSchema) {\n            addFieldSchema(subField, schema, config, buildSchemaOptions)\n          }\n        })\n      }\n    })\n  },\n  text: (\n    field: TextField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: field.hasMany ? [String] : String,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  textarea: (\n    field: TextareaField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n  upload: (\n    field: UploadField,\n    schema: Schema,\n    config: SanitizedConfig,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: Schema.Types.Mixed,\n      ref: field.relationTo,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, config.localization),\n    })\n  },\n}\n\nexport default buildSchema\n"],"names":["formatBaseSchema","field","buildSchemaOptions","disableUnique","draftsEnabled","indexSortableFields","schema","index","unique","required","localized","fieldAffectsData","type","sparse","hidden","localizeSchema","entity","localization","fieldIsLocalized","Array","isArray","locales","localeCodes","reduce","localeSchema","locale","_id","buildSchema","config","configFields","allowIDField","options","fields","schemaFields","idField","find","name","Number","String","filter","Schema","forEach","fieldIsPresentationalOnly","addFieldSchema","fieldToSchemaMap","array","baseSchema","id","minimize","default","undefined","add","blocks","fieldSchema","discriminatorKey","blockItem","blockSchema","blockField","localeCode","path","discriminator","slug","checkbox","Boolean","code","collapsible","subField","date","Date","email","group","formattedBaseSchema","json","Types","Mixed","number","hasMany","point","enum","coordinates","defaultValue","indexOptions","radio","map","option","value","relationship","hasManyRelations","relationTo","schemaToReturn","refPath","ref","richText","row","select","push","tabs","tab","tabHasName","text","textarea","upload"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
450
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/models/buildSchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n/* eslint-disable class-methods-use-this */\n/* eslint-disable @typescript-eslint/no-use-before-define */\n/* eslint-disable no-use-before-define */\nimport type { IndexOptions, SchemaOptions, SchemaTypeOptions } from 'mongoose'\nimport type { SanitizedConfig, SanitizedLocalizationConfig } from 'payload/config'\nimport type {\n  ArrayField,\n  Block,\n  BlockField,\n  CheckboxField,\n  CodeField,\n  CollapsibleField,\n  DateField,\n  EmailField,\n  Field,\n  FieldAffectingData,\n  GroupField,\n  JSONField,\n  NonPresentationalField,\n  NumberField,\n  PointField,\n  RadioField,\n  RelationshipField,\n  RichTextField,\n  RowField,\n  SelectField,\n  Tab,\n  TabsField,\n  TextField,\n  TextareaField,\n  UploadField,\n} from 'payload/types'\n\nimport { Schema } from 'mongoose'\nimport {\n  fieldAffectsData,\n  fieldIsLocalized,\n  fieldIsPresentationalOnly,\n  tabHasName,\n} from 'payload/types'\n\nimport type { MongooseAdapter } from '..'\n\nexport type BuildSchemaOptions = {\n  allowIDField?: boolean\n  disableUnique?: boolean\n  draftsEnabled?: boolean\n  indexSortableFields?: boolean\n  options?: SchemaOptions\n}\n\ntype FieldSchemaGenerator = (\n  field: Field,\n  schema: Schema,\n  adapter: MongooseAdapter,\n  buildSchemaOptions: BuildSchemaOptions,\n) => void\n\nconst formatBaseSchema = (field: FieldAffectingData, buildSchemaOptions: BuildSchemaOptions) => {\n  const { disableUnique, draftsEnabled, indexSortableFields } = buildSchemaOptions\n  const schema: SchemaTypeOptions<unknown> = {\n    index: field.index || (!disableUnique && field.unique) || indexSortableFields || false,\n    required: false,\n    unique: (!disableUnique && field.unique) || false,\n  }\n\n  if (\n    schema.unique &&\n    (field.localized ||\n      draftsEnabled ||\n      (fieldAffectsData(field) &&\n        field.type !== 'group' &&\n        field.type !== 'tab' &&\n        field.required !== true))\n  ) {\n    schema.sparse = true\n  }\n\n  if (field.hidden) {\n    schema.hidden = true\n  }\n\n  return schema\n}\n\nconst localizeSchema = (\n  entity: NonPresentationalField | Tab,\n  schema,\n  localization: SanitizedLocalizationConfig | false,\n) => {\n  if (fieldIsLocalized(entity) && localization && Array.isArray(localization.locales)) {\n    return {\n      type: localization.localeCodes.reduce(\n        (localeSchema, locale) => {\n          localeSchema[locale] = schema\n          return localeSchema\n        },\n        {\n          _id: false,\n        },\n      ),\n      localized: true,\n    }\n  }\n  return schema\n}\n\nconst buildSchema = (\n  adapter: MongooseAdapter,\n  configFields: Field[],\n  buildSchemaOptions: BuildSchemaOptions = {},\n): Schema => {\n  const { allowIDField, options } = buildSchemaOptions\n  let fields = {}\n\n  let schemaFields = configFields\n\n  if (!allowIDField) {\n    const idField = schemaFields.find((field) => fieldAffectsData(field) && field.name === 'id')\n    if (idField) {\n      fields = {\n        _id: idField.type === 'number' ? Number : String,\n      }\n      schemaFields = schemaFields.filter(\n        (field) => !(fieldAffectsData(field) && field.name === 'id'),\n      )\n    }\n  }\n\n  const schema = new Schema(fields, options)\n\n  schemaFields.forEach((field) => {\n    if (!fieldIsPresentationalOnly(field)) {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[field.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(field, schema, adapter, buildSchemaOptions)\n      }\n    }\n  })\n\n  return schema\n}\n\nconst fieldToSchemaMap: Record<string, FieldSchemaGenerator> = {\n  array: (\n    field: ArrayField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ) => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: [\n        buildSchema(adapter, field.fields, {\n          allowIDField: true,\n          disableUnique: buildSchemaOptions.disableUnique,\n          draftsEnabled: buildSchemaOptions.draftsEnabled,\n          options: {\n            minimize: false,\n            ...(buildSchemaOptions.options || {}),\n            _id: false,\n            id: false,\n            timestamps: false,\n          },\n        }),\n      ],\n      default: undefined,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  blocks: (\n    field: BlockField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const fieldSchema = {\n      type: [\n        new Schema(\n          {},\n          {\n            _id: false,\n            discriminatorKey: 'blockType',\n            ...(buildSchemaOptions.options || {}),\n            timestamps: false,\n          },\n        ),\n      ],\n      default: undefined,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, fieldSchema, adapter.payload.config.localization),\n    })\n\n    field.blocks.forEach((blockItem: Block) => {\n      const blockSchema = new Schema(\n        {},\n        {\n          ...(buildSchemaOptions.options || {}),\n          _id: false,\n          id: false,\n          timestamps: false,\n        },\n      )\n\n      blockItem.fields.forEach((blockField) => {\n        const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[blockField.type]\n        if (addFieldSchema) {\n          addFieldSchema(blockField, blockSchema, adapter, buildSchemaOptions)\n        }\n      })\n\n      if (field.localized && adapter.payload.config.localization) {\n        adapter.payload.config.localization.localeCodes.forEach((localeCode) => {\n          // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n          // @ts-expect-error Possible incorrect typing in mongoose types, this works\n          schema.path(`${field.name}.${localeCode}`).discriminator(blockItem.slug, blockSchema)\n        })\n      } else {\n        // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n        // @ts-expect-error Possible incorrect typing in mongoose types, this works\n        schema.path(field.name).discriminator(blockItem.slug, blockSchema)\n      }\n    })\n  },\n  checkbox: (\n    field: CheckboxField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Boolean }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  code: (\n    field: CodeField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  collapsible: (\n    field: CollapsibleField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.fields.forEach((subField: Field) => {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(subField, schema, adapter, buildSchemaOptions)\n      }\n    })\n  },\n  date: (\n    field: DateField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Date }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  email: (\n    field: EmailField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  group: (\n    field: GroupField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const formattedBaseSchema = formatBaseSchema(field, buildSchemaOptions)\n\n    // carry indexSortableFields through to versions if drafts enabled\n    const indexSortableFields =\n      buildSchemaOptions.indexSortableFields &&\n      field.name === 'version' &&\n      buildSchemaOptions.draftsEnabled\n\n    const baseSchema = {\n      ...formattedBaseSchema,\n      type: buildSchema(adapter, field.fields, {\n        disableUnique: buildSchemaOptions.disableUnique,\n        draftsEnabled: buildSchemaOptions.draftsEnabled,\n        indexSortableFields,\n        options: {\n          minimize: false,\n          ...(buildSchemaOptions.options || {}),\n          _id: false,\n          id: false,\n          timestamps: false,\n        },\n      }),\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  json: (\n    field: JSONField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Schema.Types.Mixed }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  number: (\n    field: NumberField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: field.hasMany ? [Number] : Number,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  point: (\n    field: PointField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema: SchemaTypeOptions<unknown> = {\n      type: {\n        type: String,\n        enum: ['Point'],\n      },\n      coordinates: {\n        type: [Number],\n        default: field.defaultValue || undefined,\n        required: false,\n      },\n    }\n    if (buildSchemaOptions.disableUnique && field.unique && field.localized) {\n      baseSchema.coordinates.sparse = true\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n\n    if (field.index === true || field.index === undefined) {\n      const indexOptions: IndexOptions = {}\n      if (!buildSchemaOptions.disableUnique && field.unique) {\n        indexOptions.sparse = true\n        indexOptions.unique = true\n      }\n      if (field.localized && adapter.payload.config.localization) {\n        adapter.payload.config.localization.locales.forEach((locale) => {\n          schema.index({ [`${field.name}.${locale.code}`]: '2dsphere' }, indexOptions)\n        })\n      } else {\n        schema.index({ [field.name]: '2dsphere' }, indexOptions)\n      }\n    }\n  },\n  radio: (\n    field: RadioField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: String,\n      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  relationship: (\n    field: RelationshipField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ) => {\n    const hasManyRelations = Array.isArray(field.relationTo)\n    let schemaToReturn: { [key: string]: any } = {}\n\n    if (field.localized && adapter.payload.config.localization) {\n      schemaToReturn = {\n        type: adapter.payload.config.localization.localeCodes.reduce((locales, locale) => {\n          let localeSchema: { [key: string]: any } = {}\n\n          if (hasManyRelations) {\n            localeSchema = {\n              ...formatBaseSchema(field, buildSchemaOptions),\n              _id: false,\n              type: Schema.Types.Mixed,\n              relationTo: { type: String, enum: field.relationTo },\n              value: {\n                type: Schema.Types.Mixed,\n                refPath: `${field.name}.${locale}.relationTo`,\n              },\n            }\n          } else {\n            localeSchema = {\n              ...formatBaseSchema(field, buildSchemaOptions),\n              type: Schema.Types.Mixed,\n              ref: field.relationTo,\n            }\n          }\n\n          return {\n            ...locales,\n            [locale]: field.hasMany ? { type: [localeSchema], default: undefined } : localeSchema,\n          }\n        }, {}),\n        localized: true,\n      }\n    } else if (hasManyRelations) {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        _id: false,\n        type: Schema.Types.Mixed,\n        relationTo: { type: String, enum: field.relationTo },\n        value: {\n          type: Schema.Types.Mixed,\n          refPath: `${field.name}.relationTo`,\n        },\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          type: [schemaToReturn],\n          default: undefined,\n        }\n      }\n    } else {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        type: Schema.Types.Mixed,\n        ref: field.relationTo,\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          type: [schemaToReturn],\n          default: undefined,\n        }\n      }\n    }\n\n    schema.add({\n      [field.name]: schemaToReturn,\n    })\n  },\n  richText: (\n    field: RichTextField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: Schema.Types.Mixed }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  row: (\n    field: RowField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.fields.forEach((subField: Field) => {\n      const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n      if (addFieldSchema) {\n        addFieldSchema(subField, schema, adapter, buildSchemaOptions)\n      }\n    })\n  },\n  select: (\n    field: SelectField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: String,\n      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n    }\n\n    if (buildSchemaOptions.draftsEnabled || !field.required) {\n      baseSchema.enum.push(null)\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(\n        field,\n        field.hasMany ? [baseSchema] : baseSchema,\n        adapter.payload.config.localization,\n      ),\n    })\n  },\n  tabs: (\n    field: TabsField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    field.tabs.forEach((tab) => {\n      if (tabHasName(tab)) {\n        const baseSchema = {\n          type: buildSchema(adapter, tab.fields, {\n            disableUnique: buildSchemaOptions.disableUnique,\n            draftsEnabled: buildSchemaOptions.draftsEnabled,\n            options: {\n              minimize: false,\n              ...(buildSchemaOptions.options || {}),\n              _id: false,\n              id: false,\n              timestamps: false,\n            },\n          }),\n        }\n\n        schema.add({\n          [tab.name]: localizeSchema(tab, baseSchema, adapter.payload.config.localization),\n        })\n      } else {\n        tab.fields.forEach((subField: Field) => {\n          const addFieldSchema: FieldSchemaGenerator = fieldToSchemaMap[subField.type]\n\n          if (addFieldSchema) {\n            addFieldSchema(subField, schema, adapter, buildSchemaOptions)\n          }\n        })\n      }\n    })\n  },\n  text: (\n    field: TextField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: field.hasMany ? [String] : String,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  textarea: (\n    field: TextareaField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n  upload: (\n    field: UploadField,\n    schema: Schema,\n    adapter: MongooseAdapter,\n    buildSchemaOptions: BuildSchemaOptions,\n  ): void => {\n    const baseSchema = {\n      ...formatBaseSchema(field, buildSchemaOptions),\n      type: Schema.Types.Mixed,\n      ref: field.relationTo,\n    }\n\n    schema.add({\n      [field.name]: localizeSchema(field, baseSchema, adapter.payload.config.localization),\n    })\n  },\n}\n\nexport default buildSchema\n"],"names":["formatBaseSchema","field","buildSchemaOptions","disableUnique","draftsEnabled","indexSortableFields","schema","index","unique","required","localized","fieldAffectsData","type","sparse","hidden","localizeSchema","entity","localization","fieldIsLocalized","Array","isArray","locales","localeCodes","reduce","localeSchema","locale","_id","buildSchema","adapter","configFields","allowIDField","options","fields","schemaFields","idField","find","name","Number","String","filter","Schema","forEach","fieldIsPresentationalOnly","addFieldSchema","fieldToSchemaMap","array","baseSchema","minimize","id","timestamps","default","undefined","add","payload","config","blocks","fieldSchema","discriminatorKey","blockItem","blockSchema","blockField","localeCode","path","discriminator","slug","checkbox","Boolean","code","collapsible","subField","date","Date","email","group","formattedBaseSchema","json","Types","Mixed","number","hasMany","point","enum","coordinates","defaultValue","indexOptions","radio","map","option","value","relationship","hasManyRelations","relationTo","schemaToReturn","refPath","ref","richText","row","select","push","tabs","tab","tabHasName","text","textarea","upload"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAWnD,eAAO,MAAM,WAAW,EAAE,WA0FzB,CAAA"}
1
+ {"version":3,"file":"queryDrafts.d.ts","sourceRoot":"","sources":["../src/queryDrafts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAWnD,eAAO,MAAM,WAAW,EAAE,WAgGzB,CAAA"}
@@ -20,7 +20,7 @@ function _interop_require_default(obj) {
20
20
  const queryDrafts = async function queryDrafts({ collection, limit, locale, page, pagination, req = {}, sort: sortArg, where }) {
21
21
  const VersionModel = this.versions[collection];
22
22
  const collectionConfig = this.payload.collections[collection].config;
23
- const options = (0, _withSession.withSession)(this, req.transactionID);
23
+ const options = await (0, _withSession.withSession)(this, req);
24
24
  let hasNearConstraint;
25
25
  let sort;
26
26
  if (where) {
@@ -58,6 +58,12 @@ const queryDrafts = async function queryDrafts({ collection, limit, locale, page
58
58
  sort,
59
59
  useEstimatedCount
60
60
  };
61
+ if (locale && locale !== 'all' && locale !== '*') {
62
+ paginationOptions.collation = {
63
+ locale,
64
+ strength: 1
65
+ };
66
+ }
61
67
  if (!useEstimatedCount && Object.keys(versionQuery).length === 0 && this.disableIndexHints !== true) {
62
68
  // Improve the performance of the countDocuments query which is used if useEstimatedCount is set to false by adding
63
69
  // a hint. By default, if no hint is provided, MongoDB does not use an indexed field to count the returned documents,
@@ -77,7 +83,7 @@ const queryDrafts = async function queryDrafts({ collection, limit, locale, page
77
83
  paginationOptions.options.limit = limit;
78
84
  }
79
85
  const result = await VersionModel.paginate(versionQuery, paginationOptions);
80
- const docs = JSON.parse(JSON.stringify(result.docs));
86
+ const docs = this.jsonParse ? JSON.parse(JSON.stringify(result.docs)) : result.docs;
81
87
  return {
82
88
  ...result,
83
89
  docs: docs.map((doc)=>{
@@ -94,4 +100,4 @@ const queryDrafts = async function queryDrafts({ collection, limit, locale, page
94
100
  };
95
101
  };
96
102
 
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/queryDrafts.ts"],"sourcesContent":["import type { PaginateOptions } from 'mongoose'\nimport type { QueryDrafts } from 'payload/database'\nimport type { PayloadRequest } from 'payload/types'\n\nimport { combineQueries, flattenWhereToOperators } from 'payload/database'\n\nimport type { MongooseAdapter } from '.'\n\nimport { buildSortParam } from './queries/buildSortParam'\nimport sanitizeInternalFields from './utilities/sanitizeInternalFields'\nimport { withSession } from './withSession'\n\nexport const queryDrafts: QueryDrafts = async function queryDrafts(\n  this: MongooseAdapter,\n  { collection, limit, locale, page, pagination, req = {} as PayloadRequest, sort: sortArg, where },\n) {\n  const VersionModel = this.versions[collection]\n  const collectionConfig = this.payload.collections[collection].config\n  const options = withSession(this, req.transactionID)\n\n  let hasNearConstraint\n  let sort\n\n  if (where) {\n    const constraints = flattenWhereToOperators(where)\n    hasNearConstraint = constraints.some((prop) => Object.keys(prop).some((key) => key === 'near'))\n  }\n\n  if (!hasNearConstraint) {\n    sort = buildSortParam({\n      config: this.payload.config,\n      fields: collectionConfig.fields,\n      locale,\n      sort: sortArg || collectionConfig.defaultSort,\n      timestamps: true,\n    })\n  }\n\n  const combinedWhere = combineQueries({ latest: { equals: true } }, where)\n\n  const versionQuery = await VersionModel.buildQuery({\n    locale,\n    payload: this.payload,\n    where: combinedWhere,\n  })\n\n  // useEstimatedCount is faster, but not accurate, as it ignores any filters. It is thus set to true if there are no filters.\n  const useEstimatedCount =\n    hasNearConstraint || !versionQuery || Object.keys(versionQuery).length === 0\n  const paginationOptions: PaginateOptions = {\n    forceCountFn: hasNearConstraint,\n    lean: true,\n    leanWithId: true,\n    options,\n    page,\n    pagination,\n    sort,\n    useEstimatedCount,\n  }\n\n  if (\n    !useEstimatedCount &&\n    Object.keys(versionQuery).length === 0 &&\n    this.disableIndexHints !== true\n  ) {\n    // Improve the performance of the countDocuments query which is used if useEstimatedCount is set to false by adding\n    // a hint. By default, if no hint is provided, MongoDB does not use an indexed field to count the returned documents,\n    // which makes queries very slow. This only happens when no query (filter) is provided. If one is provided, it uses\n    // the correct indexed field\n    paginationOptions.useCustomCountFn = () => {\n      return Promise.resolve(\n        VersionModel.countDocuments(versionQuery, {\n          hint: { _id: 1 },\n        }),\n      )\n    }\n  }\n\n  if (limit > 0) {\n    paginationOptions.limit = limit\n    // limit must also be set here, it's ignored when pagination is false\n    paginationOptions.options.limit = limit\n  }\n\n  const result = await VersionModel.paginate(versionQuery, paginationOptions)\n  const docs = JSON.parse(JSON.stringify(result.docs))\n\n  return {\n    ...result,\n    docs: docs.map((doc) => {\n      // eslint-disable-next-line no-param-reassign\n      doc = {\n        _id: doc.parent,\n        id: doc.parent,\n        ...doc.version,\n        createdAt: doc.createdAt,\n        updatedAt: doc.updatedAt,\n      }\n\n      return sanitizeInternalFields(doc)\n    }),\n  }\n}\n"],"names":["queryDrafts","collection","limit","locale","page","pagination","req","sort","sortArg","where","VersionModel","versions","collectionConfig","payload","collections","config","options","withSession","transactionID","hasNearConstraint","constraints","flattenWhereToOperators","some","prop","Object","keys","key","buildSortParam","fields","defaultSort","timestamps","combinedWhere","combineQueries","latest","equals","versionQuery","buildQuery","useEstimatedCount","length","paginationOptions","forceCountFn","lean","leanWithId","disableIndexHints","useCustomCountFn","Promise","resolve","countDocuments","hint","_id","result","paginate","docs","JSON","parse","stringify","map","doc","parent","id","version","createdAt","updatedAt","sanitizeInternalFields"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BAYaA;;;eAAAA;;;0BAR2C;gCAIzB;+EACI;6BACP;;;;;;AAErB,MAAMA,cAA2B,eAAeA,YAErD,EAAEC,UAAU,EAAEC,KAAK,EAAEC,MAAM,EAAEC,IAAI,EAAEC,UAAU,EAAEC,MAAM,CAAC,CAAmB,EAAEC,MAAMC,OAAO,EAAEC,KAAK,EAAE;IAEjG,MAAMC,eAAe,IAAI,CAACC,QAAQ,CAACV,WAAW;IAC9C,MAAMW,mBAAmB,IAAI,CAACC,OAAO,CAACC,WAAW,CAACb,WAAW,CAACc,MAAM;IACpE,MAAMC,UAAUC,IAAAA,wBAAW,EAAC,IAAI,EAAEX,IAAIY,aAAa;IAEnD,IAAIC;IACJ,IAAIZ;IAEJ,IAAIE,OAAO;QACT,MAAMW,cAAcC,IAAAA,iCAAuB,EAACZ;QAC5CU,oBAAoBC,YAAYE,IAAI,CAAC,CAACC,OAASC,OAAOC,IAAI,CAACF,MAAMD,IAAI,CAAC,CAACI,MAAQA,QAAQ;IACzF;IAEA,IAAI,CAACP,mBAAmB;QACtBZ,OAAOoB,IAAAA,8BAAc,EAAC;YACpBZ,QAAQ,IAAI,CAACF,OAAO,CAACE,MAAM;YAC3Ba,QAAQhB,iBAAiBgB,MAAM;YAC/BzB;YACAI,MAAMC,WAAWI,iBAAiBiB,WAAW;YAC7CC,YAAY;QACd;IACF;IAEA,MAAMC,gBAAgBC,IAAAA,wBAAc,EAAC;QAAEC,QAAQ;YAAEC,QAAQ;QAAK;IAAE,GAAGzB;IAEnE,MAAM0B,eAAe,MAAMzB,aAAa0B,UAAU,CAAC;QACjDjC;QACAU,SAAS,IAAI,CAACA,OAAO;QACrBJ,OAAOsB;IACT;IAEA,4HAA4H;IAC5H,MAAMM,oBACJlB,qBAAqB,CAACgB,gBAAgBX,OAAOC,IAAI,CAACU,cAAcG,MAAM,KAAK;IAC7E,MAAMC,oBAAqC;QACzCC,cAAcrB;QACdsB,MAAM;QACNC,YAAY;QACZ1B;QACAZ;QACAC;QACAE;QACA8B;IACF;IAEA,IACE,CAACA,qBACDb,OAAOC,IAAI,CAACU,cAAcG,MAAM,KAAK,KACrC,IAAI,CAACK,iBAAiB,KAAK,MAC3B;QACA,mHAAmH;QACnH,qHAAqH;QACrH,mHAAmH;QACnH,4BAA4B;QAC5BJ,kBAAkBK,gBAAgB,GAAG;YACnC,OAAOC,QAAQC,OAAO,CACpBpC,aAAaqC,cAAc,CAACZ,cAAc;gBACxCa,MAAM;oBAAEC,KAAK;gBAAE;YACjB;QAEJ;IACF;IAEA,IAAI/C,QAAQ,GAAG;QACbqC,kBAAkBrC,KAAK,GAAGA;QAC1B,qEAAqE;QACrEqC,kBAAkBvB,OAAO,CAACd,KAAK,GAAGA;IACpC;IAEA,MAAMgD,SAAS,MAAMxC,aAAayC,QAAQ,CAAChB,cAAcI;IACzD,MAAMa,OAAOC,KAAKC,KAAK,CAACD,KAAKE,SAAS,CAACL,OAAOE,IAAI;IAElD,OAAO;QACL,GAAGF,MAAM;QACTE,MAAMA,KAAKI,GAAG,CAAC,CAACC;YACd,6CAA6C;YAC7CA,MAAM;gBACJR,KAAKQ,IAAIC,MAAM;gBACfC,IAAIF,IAAIC,MAAM;gBACd,GAAGD,IAAIG,OAAO;gBACdC,WAAWJ,IAAII,SAAS;gBACxBC,WAAWL,IAAIK,SAAS;YAC1B;YAEA,OAAOC,IAAAA,+BAAsB,EAACN;QAChC;IACF;AACF"}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/queryDrafts.ts"],"sourcesContent":["import type { PaginateOptions } from 'mongoose'\nimport type { QueryDrafts } from 'payload/database'\nimport type { PayloadRequest } from 'payload/types'\n\nimport { combineQueries, flattenWhereToOperators } from 'payload/database'\n\nimport type { MongooseAdapter } from '.'\n\nimport { buildSortParam } from './queries/buildSortParam'\nimport sanitizeInternalFields from './utilities/sanitizeInternalFields'\nimport { withSession } from './withSession'\n\nexport const queryDrafts: QueryDrafts = async function queryDrafts(\n  this: MongooseAdapter,\n  { collection, limit, locale, page, pagination, req = {} as PayloadRequest, sort: sortArg, where },\n) {\n  const VersionModel = this.versions[collection]\n  const collectionConfig = this.payload.collections[collection].config\n  const options = await withSession(this, req)\n\n  let hasNearConstraint\n  let sort\n\n  if (where) {\n    const constraints = flattenWhereToOperators(where)\n    hasNearConstraint = constraints.some((prop) => Object.keys(prop).some((key) => key === 'near'))\n  }\n\n  if (!hasNearConstraint) {\n    sort = buildSortParam({\n      config: this.payload.config,\n      fields: collectionConfig.fields,\n      locale,\n      sort: sortArg || collectionConfig.defaultSort,\n      timestamps: true,\n    })\n  }\n\n  const combinedWhere = combineQueries({ latest: { equals: true } }, where)\n\n  const versionQuery = await VersionModel.buildQuery({\n    locale,\n    payload: this.payload,\n    where: combinedWhere,\n  })\n\n  // useEstimatedCount is faster, but not accurate, as it ignores any filters. It is thus set to true if there are no filters.\n  const useEstimatedCount =\n    hasNearConstraint || !versionQuery || Object.keys(versionQuery).length === 0\n  const paginationOptions: PaginateOptions = {\n    forceCountFn: hasNearConstraint,\n    lean: true,\n    leanWithId: true,\n    options,\n    page,\n    pagination,\n    sort,\n    useEstimatedCount,\n  }\n\n  if (locale && locale !== 'all' && locale !== '*') {\n    paginationOptions.collation = { locale, strength: 1 }\n  }\n\n  if (\n    !useEstimatedCount &&\n    Object.keys(versionQuery).length === 0 &&\n    this.disableIndexHints !== true\n  ) {\n    // Improve the performance of the countDocuments query which is used if useEstimatedCount is set to false by adding\n    // a hint. By default, if no hint is provided, MongoDB does not use an indexed field to count the returned documents,\n    // which makes queries very slow. This only happens when no query (filter) is provided. If one is provided, it uses\n    // the correct indexed field\n    paginationOptions.useCustomCountFn = () => {\n      return Promise.resolve(\n        VersionModel.countDocuments(versionQuery, {\n          hint: { _id: 1 },\n        }),\n      )\n    }\n  }\n\n  if (limit > 0) {\n    paginationOptions.limit = limit\n    // limit must also be set here, it's ignored when pagination is false\n    paginationOptions.options.limit = limit\n  }\n\n  const result = await VersionModel.paginate(versionQuery, paginationOptions)\n\n  const docs = this.jsonParse ? JSON.parse(JSON.stringify(result.docs)) : result.docs\n\n  return {\n    ...result,\n    docs: docs.map((doc) => {\n      // eslint-disable-next-line no-param-reassign\n\n      doc = {\n        _id: doc.parent,\n        id: doc.parent,\n        ...doc.version,\n        createdAt: doc.createdAt,\n        updatedAt: doc.updatedAt,\n      }\n\n      return sanitizeInternalFields(doc)\n    }),\n  }\n}\n"],"names":["queryDrafts","collection","limit","locale","page","pagination","req","sort","sortArg","where","VersionModel","versions","collectionConfig","payload","collections","config","options","withSession","hasNearConstraint","constraints","flattenWhereToOperators","some","prop","Object","keys","key","buildSortParam","fields","defaultSort","timestamps","combinedWhere","combineQueries","latest","equals","versionQuery","buildQuery","useEstimatedCount","length","paginationOptions","forceCountFn","lean","leanWithId","collation","strength","disableIndexHints","useCustomCountFn","Promise","resolve","countDocuments","hint","_id","result","paginate","docs","jsonParse","JSON","parse","stringify","map","doc","parent","id","version","createdAt","updatedAt","sanitizeInternalFields"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;+BAYaA;;;eAAAA;;;0BAR2C;gCAIzB;+EACI;6BACP;;;;;;AAErB,MAAMA,cAA2B,eAAeA,YAErD,EAAEC,UAAU,EAAEC,KAAK,EAAEC,MAAM,EAAEC,IAAI,EAAEC,UAAU,EAAEC,MAAM,CAAC,CAAmB,EAAEC,MAAMC,OAAO,EAAEC,KAAK,EAAE;IAEjG,MAAMC,eAAe,IAAI,CAACC,QAAQ,CAACV,WAAW;IAC9C,MAAMW,mBAAmB,IAAI,CAACC,OAAO,CAACC,WAAW,CAACb,WAAW,CAACc,MAAM;IACpE,MAAMC,UAAU,MAAMC,IAAAA,wBAAW,EAAC,IAAI,EAAEX;IAExC,IAAIY;IACJ,IAAIX;IAEJ,IAAIE,OAAO;QACT,MAAMU,cAAcC,IAAAA,iCAAuB,EAACX;QAC5CS,oBAAoBC,YAAYE,IAAI,CAAC,CAACC,OAASC,OAAOC,IAAI,CAACF,MAAMD,IAAI,CAAC,CAACI,MAAQA,QAAQ;IACzF;IAEA,IAAI,CAACP,mBAAmB;QACtBX,OAAOmB,IAAAA,8BAAc,EAAC;YACpBX,QAAQ,IAAI,CAACF,OAAO,CAACE,MAAM;YAC3BY,QAAQf,iBAAiBe,MAAM;YAC/BxB;YACAI,MAAMC,WAAWI,iBAAiBgB,WAAW;YAC7CC,YAAY;QACd;IACF;IAEA,MAAMC,gBAAgBC,IAAAA,wBAAc,EAAC;QAAEC,QAAQ;YAAEC,QAAQ;QAAK;IAAE,GAAGxB;IAEnE,MAAMyB,eAAe,MAAMxB,aAAayB,UAAU,CAAC;QACjDhC;QACAU,SAAS,IAAI,CAACA,OAAO;QACrBJ,OAAOqB;IACT;IAEA,4HAA4H;IAC5H,MAAMM,oBACJlB,qBAAqB,CAACgB,gBAAgBX,OAAOC,IAAI,CAACU,cAAcG,MAAM,KAAK;IAC7E,MAAMC,oBAAqC;QACzCC,cAAcrB;QACdsB,MAAM;QACNC,YAAY;QACZzB;QACAZ;QACAC;QACAE;QACA6B;IACF;IAEA,IAAIjC,UAAUA,WAAW,SAASA,WAAW,KAAK;QAChDmC,kBAAkBI,SAAS,GAAG;YAAEvC;YAAQwC,UAAU;QAAE;IACtD;IAEA,IACE,CAACP,qBACDb,OAAOC,IAAI,CAACU,cAAcG,MAAM,KAAK,KACrC,IAAI,CAACO,iBAAiB,KAAK,MAC3B;QACA,mHAAmH;QACnH,qHAAqH;QACrH,mHAAmH;QACnH,4BAA4B;QAC5BN,kBAAkBO,gBAAgB,GAAG;YACnC,OAAOC,QAAQC,OAAO,CACpBrC,aAAasC,cAAc,CAACd,cAAc;gBACxCe,MAAM;oBAAEC,KAAK;gBAAE;YACjB;QAEJ;IACF;IAEA,IAAIhD,QAAQ,GAAG;QACboC,kBAAkBpC,KAAK,GAAGA;QAC1B,qEAAqE;QACrEoC,kBAAkBtB,OAAO,CAACd,KAAK,GAAGA;IACpC;IAEA,MAAMiD,SAAS,MAAMzC,aAAa0C,QAAQ,CAAClB,cAAcI;IAEzD,MAAMe,OAAO,IAAI,CAACC,SAAS,GAAGC,KAAKC,KAAK,CAACD,KAAKE,SAAS,CAACN,OAAOE,IAAI,KAAKF,OAAOE,IAAI;IAEnF,OAAO;QACL,GAAGF,MAAM;QACTE,MAAMA,KAAKK,GAAG,CAAC,CAACC;YACd,6CAA6C;YAE7CA,MAAM;gBACJT,KAAKS,IAAIC,MAAM;gBACfC,IAAIF,IAAIC,MAAM;gBACd,GAAGD,IAAIG,OAAO;gBACdC,WAAWJ,IAAII,SAAS;gBACxBC,WAAWL,IAAIK,SAAS;YAC1B;YAEA,OAAOC,IAAAA,+BAAsB,EAACN;QAChC;IACF;AACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"commitTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/commitTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,eAAO,MAAM,iBAAiB,EAAE,iBAY/B,CAAA"}
1
+ {"version":3,"file":"commitTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/commitTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,eAAO,MAAM,iBAAiB,EAAE,iBAc/B,CAAA"}