@payloadcms/db-mongodb 1.0.0-beta.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 (124) hide show
  1. package/dist/connect.d.ts +3 -0
  2. package/dist/connect.d.ts.map +1 -0
  3. package/dist/connect.js +63 -0
  4. package/dist/create.d.ts +3 -0
  5. package/dist/create.d.ts.map +1 -0
  6. package/dist/create.js +29 -0
  7. package/dist/createGlobal.d.ts +3 -0
  8. package/dist/createGlobal.d.ts.map +1 -0
  9. package/dist/createGlobal.js +35 -0
  10. package/dist/createGlobalVersion.d.ts +3 -0
  11. package/dist/createGlobalVersion.d.ts.map +1 -0
  12. package/dist/createGlobalVersion.js +58 -0
  13. package/dist/createVersion.d.ts +3 -0
  14. package/dist/createVersion.d.ts.map +1 -0
  15. package/dist/createVersion.js +58 -0
  16. package/dist/deleteMany.d.ts +3 -0
  17. package/dist/deleteMany.d.ts.map +1 -0
  18. package/dist/deleteMany.js +25 -0
  19. package/dist/deleteOne.d.ts +3 -0
  20. package/dist/deleteOne.d.ts.map +1 -0
  21. package/dist/deleteOne.js +33 -0
  22. package/dist/deleteVersions.d.ts +3 -0
  23. package/dist/deleteVersions.d.ts.map +1 -0
  24. package/dist/deleteVersions.js +26 -0
  25. package/dist/destroy.d.ts +3 -0
  26. package/dist/destroy.d.ts.map +1 -0
  27. package/dist/destroy.js +27 -0
  28. package/dist/find.d.ts +3 -0
  29. package/dist/find.d.ts.map +1 -0
  30. package/dist/find.js +71 -0
  31. package/dist/findGlobal.d.ts +3 -0
  32. package/dist/findGlobal.d.ts.map +1 -0
  33. package/dist/findGlobal.js +48 -0
  34. package/dist/findGlobalVersions.d.ts +3 -0
  35. package/dist/findGlobalVersions.d.ts.map +1 -0
  36. package/dist/findGlobalVersions.js +78 -0
  37. package/dist/findOne.d.ts +3 -0
  38. package/dist/findOne.d.ts.map +1 -0
  39. package/dist/findOne.js +40 -0
  40. package/dist/findVersions.d.ts +3 -0
  41. package/dist/findVersions.d.ts.map +1 -0
  42. package/dist/findVersions.js +77 -0
  43. package/dist/index.d.ts +34 -0
  44. package/dist/index.d.ts.map +1 -0
  45. package/dist/index.js +91 -0
  46. package/dist/init.d.ts +3 -0
  47. package/dist/init.d.ts.map +1 -0
  48. package/dist/init.js +98 -0
  49. package/dist/mock.js +13 -0
  50. package/dist/models/buildCollectionSchema.d.ts +6 -0
  51. package/dist/models/buildCollectionSchema.d.ts.map +1 -0
  52. package/dist/models/buildCollectionSchema.js +51 -0
  53. package/dist/models/buildGlobalModel.d.ts +4 -0
  54. package/dist/models/buildGlobalModel.d.ts.map +1 -0
  55. package/dist/models/buildGlobalModel.js +41 -0
  56. package/dist/models/buildSchema.d.ts +14 -0
  57. package/dist/models/buildSchema.d.ts.map +1 -0
  58. package/dist/models/buildSchema.js +438 -0
  59. package/dist/queries/buildAndOrConditions.d.ts +11 -0
  60. package/dist/queries/buildAndOrConditions.d.ts.map +1 -0
  61. package/dist/queries/buildAndOrConditions.js +37 -0
  62. package/dist/queries/buildQuery.d.ts +15 -0
  63. package/dist/queries/buildQuery.d.ts.map +1 -0
  64. package/dist/queries/buildQuery.js +49 -0
  65. package/dist/queries/buildSearchParams.d.ts +21 -0
  66. package/dist/queries/buildSearchParams.d.ts.map +1 -0
  67. package/dist/queries/buildSearchParams.js +219 -0
  68. package/dist/queries/buildSortParam.d.ts +18 -0
  69. package/dist/queries/buildSortParam.d.ts.map +1 -0
  70. package/dist/queries/buildSortParam.js +42 -0
  71. package/dist/queries/getLocalizedSortProperty.d.ts +12 -0
  72. package/dist/queries/getLocalizedSortProperty.d.ts.map +1 -0
  73. package/dist/queries/getLocalizedSortProperty.js +76 -0
  74. package/dist/queries/getLocalizedSortProperty.spec.js +195 -0
  75. package/dist/queries/mock.js +3 -0
  76. package/dist/queries/operatorMap.d.ts +16 -0
  77. package/dist/queries/operatorMap.d.ts.map +1 -0
  78. package/dist/queries/operatorMap.js +27 -0
  79. package/dist/queries/parseParams.d.ts +12 -0
  80. package/dist/queries/parseParams.d.ts.map +1 -0
  81. package/dist/queries/parseParams.js +80 -0
  82. package/dist/queries/sanitizeQueryValue.d.ts +11 -0
  83. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -0
  84. package/dist/queries/sanitizeQueryValue.js +128 -0
  85. package/dist/queryDrafts.d.ts +3 -0
  86. package/dist/queryDrafts.d.ts.map +1 -0
  87. package/dist/queryDrafts.js +82 -0
  88. package/dist/testCredentials.d.ts +8 -0
  89. package/dist/testCredentials.d.ts.map +1 -0
  90. package/dist/testCredentials.js +30 -0
  91. package/dist/transactions/beginTransaction.d.ts +3 -0
  92. package/dist/transactions/beginTransaction.d.ts.map +1 -0
  93. package/dist/transactions/beginTransaction.js +38 -0
  94. package/dist/transactions/commitTransaction.d.ts +3 -0
  95. package/dist/transactions/commitTransaction.d.ts.map +1 -0
  96. package/dist/transactions/commitTransaction.js +24 -0
  97. package/dist/transactions/rollbackTransaction.d.ts +3 -0
  98. package/dist/transactions/rollbackTransaction.d.ts.map +1 -0
  99. package/dist/transactions/rollbackTransaction.js +21 -0
  100. package/dist/types.d.ts +70 -0
  101. package/dist/types.d.ts.map +1 -0
  102. package/dist/types.js +6 -0
  103. package/dist/updateGlobal.d.ts +3 -0
  104. package/dist/updateGlobal.d.ts.map +1 -0
  105. package/dist/updateGlobal.js +36 -0
  106. package/dist/updateGlobalVersion.d.ts +5 -0
  107. package/dist/updateGlobalVersion.d.ts.map +1 -0
  108. package/dist/updateGlobalVersion.js +35 -0
  109. package/dist/updateOne.d.ts +3 -0
  110. package/dist/updateOne.d.ts.map +1 -0
  111. package/dist/updateOne.js +55 -0
  112. package/dist/updateVersion.d.ts +3 -0
  113. package/dist/updateVersion.d.ts.map +1 -0
  114. package/dist/updateVersion.js +35 -0
  115. package/dist/utilities/sanitizeInternalFields.d.ts +3 -0
  116. package/dist/utilities/sanitizeInternalFields.d.ts.map +1 -0
  117. package/dist/utilities/sanitizeInternalFields.js +31 -0
  118. package/dist/webpack.d.ts +3 -0
  119. package/dist/webpack.d.ts.map +1 -0
  120. package/dist/webpack.js +30 -0
  121. package/dist/withSession.d.ts +10 -0
  122. package/dist/withSession.d.ts.map +1 -0
  123. package/dist/withSession.js +17 -0
  124. package/package.json +43 -0
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "buildGlobalModel", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return buildGlobalModel;
9
+ }
10
+ });
11
+ const _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
12
+ const _buildQuery = /*#__PURE__*/ _interop_require_default(require("../queries/buildQuery"));
13
+ const _buildSchema = /*#__PURE__*/ _interop_require_default(require("./buildSchema"));
14
+ function _interop_require_default(obj) {
15
+ return obj && obj.__esModule ? obj : {
16
+ default: obj
17
+ };
18
+ }
19
+ const buildGlobalModel = (config)=>{
20
+ if (config.globals && config.globals.length > 0) {
21
+ const globalsSchema = new _mongoose.default.Schema({}, {
22
+ discriminatorKey: 'globalType',
23
+ minimize: false,
24
+ timestamps: true
25
+ });
26
+ globalsSchema.plugin((0, _buildQuery.default)());
27
+ const Globals = _mongoose.default.model('globals', globalsSchema, 'globals');
28
+ Object.values(config.globals).forEach((globalConfig)=>{
29
+ const globalSchema = (0, _buildSchema.default)(config, globalConfig.fields, {
30
+ options: {
31
+ minimize: false
32
+ }
33
+ });
34
+ Globals.discriminator(globalConfig.slug, globalSchema);
35
+ });
36
+ return Globals;
37
+ }
38
+ return null;
39
+ };
40
+
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tb2RlbHMvYnVpbGRHbG9iYWxNb2RlbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFNhbml0aXplZENvbmZpZyB9IGZyb20gJ3BheWxvYWQvY29uZmlnJ1xuXG5pbXBvcnQgbW9uZ29vc2UgZnJvbSAnbW9uZ29vc2UnXG5cbmltcG9ydCB0eXBlIHsgR2xvYmFsTW9kZWwgfSBmcm9tICcuLi90eXBlcydcblxuaW1wb3J0IGdldEJ1aWxkUXVlcnlQbHVnaW4gZnJvbSAnLi4vcXVlcmllcy9idWlsZFF1ZXJ5J1xuaW1wb3J0IGJ1aWxkU2NoZW1hIGZyb20gJy4vYnVpbGRTY2hlbWEnXG5cbmV4cG9ydCBjb25zdCBidWlsZEdsb2JhbE1vZGVsID0gKGNvbmZpZzogU2FuaXRpemVkQ29uZmlnKTogR2xvYmFsTW9kZWwgfCBudWxsID0+IHtcbiAgaWYgKGNvbmZpZy5nbG9iYWxzICYmIGNvbmZpZy5nbG9iYWxzLmxlbmd0aCA+IDApIHtcbiAgICBjb25zdCBnbG9iYWxzU2NoZW1hID0gbmV3IG1vbmdvb3NlLlNjaGVtYShcbiAgICAgIHt9LFxuICAgICAgeyBkaXNjcmltaW5hdG9yS2V5OiAnZ2xvYmFsVHlwZScsIG1pbmltaXplOiBmYWxzZSwgdGltZXN0YW1wczogdHJ1ZSB9LFxuICAgIClcblxuICAgIGdsb2JhbHNTY2hlbWEucGx1Z2luKGdldEJ1aWxkUXVlcnlQbHVnaW4oKSlcblxuICAgIGNvbnN0IEdsb2JhbHMgPSBtb25nb29zZS5tb2RlbCgnZ2xvYmFscycsIGdsb2JhbHNTY2hlbWEsICdnbG9iYWxzJykgYXMgdW5rbm93biBhcyBHbG9iYWxNb2RlbFxuXG4gICAgT2JqZWN0LnZhbHVlcyhjb25maWcuZ2xvYmFscykuZm9yRWFjaCgoZ2xvYmFsQ29uZmlnKSA9PiB7XG4gICAgICBjb25zdCBnbG9iYWxTY2hlbWEgPSBidWlsZFNjaGVtYShjb25maWcsIGdsb2JhbENvbmZpZy5maWVsZHMsIHtcbiAgICAgICAgb3B0aW9uczoge1xuICAgICAgICAgIG1pbmltaXplOiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgIH0pXG4gICAgICBHbG9iYWxzLmRpc2NyaW1pbmF0b3IoZ2xvYmFsQ29uZmlnLnNsdWcsIGdsb2JhbFNjaGVtYSlcbiAgICB9KVxuXG4gICAgcmV0dXJuIEdsb2JhbHNcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXSwibmFtZXMiOlsiYnVpbGRHbG9iYWxNb2RlbCIsImNvbmZpZyIsImdsb2JhbHMiLCJsZW5ndGgiLCJnbG9iYWxzU2NoZW1hIiwibW9uZ29vc2UiLCJTY2hlbWEiLCJkaXNjcmltaW5hdG9yS2V5IiwibWluaW1pemUiLCJ0aW1lc3RhbXBzIiwicGx1Z2luIiwiZ2V0QnVpbGRRdWVyeVBsdWdpbiIsIkdsb2JhbHMiLCJtb2RlbCIsIk9iamVjdCIsInZhbHVlcyIsImZvckVhY2giLCJnbG9iYWxDb25maWciLCJnbG9iYWxTY2hlbWEiLCJidWlsZFNjaGVtYSIsImZpZWxkcyIsIm9wdGlvbnMiLCJkaXNjcmltaW5hdG9yIiwic2x1ZyJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFTYUE7OztlQUFBQTs7O2lFQVBRO21FQUlXO29FQUNSOzs7Ozs7QUFFakIsTUFBTUEsbUJBQW1CLENBQUNDO0lBQy9CLElBQUlBLE9BQU9DLE9BQU8sSUFBSUQsT0FBT0MsT0FBTyxDQUFDQyxNQUFNLEdBQUcsR0FBRztRQUMvQyxNQUFNQyxnQkFBZ0IsSUFBSUMsaUJBQVEsQ0FBQ0MsTUFBTSxDQUN2QyxDQUFDLEdBQ0Q7WUFBRUMsa0JBQWtCO1lBQWNDLFVBQVU7WUFBT0MsWUFBWTtRQUFLO1FBR3RFTCxjQUFjTSxNQUFNLENBQUNDLElBQUFBLG1CQUFtQjtRQUV4QyxNQUFNQyxVQUFVUCxpQkFBUSxDQUFDUSxLQUFLLENBQUMsV0FBV1QsZUFBZTtRQUV6RFUsT0FBT0MsTUFBTSxDQUFDZCxPQUFPQyxPQUFPLEVBQUVjLE9BQU8sQ0FBQyxDQUFDQztZQUNyQyxNQUFNQyxlQUFlQyxJQUFBQSxvQkFBVyxFQUFDbEIsUUFBUWdCLGFBQWFHLE1BQU0sRUFBRTtnQkFDNURDLFNBQVM7b0JBQ1BiLFVBQVU7Z0JBQ1o7WUFDRjtZQUNBSSxRQUFRVSxhQUFhLENBQUNMLGFBQWFNLElBQUksRUFBRUw7UUFDM0M7UUFFQSxPQUFPTjtJQUNUO0lBRUEsT0FBTztBQUNUIn0=
@@ -0,0 +1,14 @@
1
+ import type { SchemaOptions } from 'mongoose';
2
+ import type { SanitizedConfig } from 'payload/config';
3
+ import type { Field } from 'payload/types';
4
+ import { Schema } from 'mongoose';
5
+ export type BuildSchemaOptions = {
6
+ allowIDField?: boolean;
7
+ disableUnique?: boolean;
8
+ draftsEnabled?: boolean;
9
+ indexSortableFields?: boolean;
10
+ options?: SchemaOptions;
11
+ };
12
+ declare const buildSchema: (config: SanitizedConfig, configFields: Field[], buildSchemaOptions?: BuildSchemaOptions) => Schema;
13
+ export default buildSchema;
14
+ //# sourceMappingURL=buildSchema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildSchema.d.ts","sourceRoot":"","sources":["../../src/models/buildSchema.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAgB,aAAa,EAAqB,MAAM,UAAU,CAAA;AAC9E,OAAO,KAAK,EAAE,eAAe,EAA+B,MAAM,gBAAgB,CAAA;AAClF,OAAO,KAAK,EASV,KAAK,EAcN,MAAM,eAAe,CAAA;AAGtB,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAQjC,MAAM,MAAM,kBAAkB,GAAG;IAC/B,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,OAAO,CAAC,EAAE,aAAa,CAAA;CACxB,CAAA;AAkDD,QAAA,MAAM,WAAW,WACP,eAAe,gBACT,KAAK,EAAE,uBACD,kBAAkB,KACrC,MA+BF,CAAA;AAscD,eAAe,WAAW,CAAA"}
@@ -0,0 +1,438 @@
1
+ /* eslint-disable @typescript-eslint/ban-ts-comment */ /* eslint-disable class-methods-use-this */ /* eslint-disable @typescript-eslint/no-use-before-define */ /* eslint-disable no-use-before-define */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "default", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return _default;
9
+ }
10
+ });
11
+ const _mongoose = require("mongoose");
12
+ const _types = require("payload/types");
13
+ const formatBaseSchema = (field, buildSchemaOptions)=>{
14
+ const { disableUnique, draftsEnabled, indexSortableFields } = buildSchemaOptions;
15
+ const schema = {
16
+ index: field.index || !disableUnique && field.unique || indexSortableFields || false,
17
+ required: false,
18
+ unique: !disableUnique && field.unique || false
19
+ };
20
+ if (schema.unique && (field.localized || draftsEnabled)) {
21
+ schema.sparse = true;
22
+ }
23
+ if (field.hidden) {
24
+ schema.hidden = true;
25
+ }
26
+ return schema;
27
+ };
28
+ const localizeSchema = (entity, schema, localization)=>{
29
+ if ((0, _types.fieldIsLocalized)(entity) && localization && Array.isArray(localization.locales)) {
30
+ return {
31
+ localized: true,
32
+ type: localization.localeCodes.reduce((localeSchema, locale)=>({
33
+ ...localeSchema,
34
+ [locale]: schema
35
+ }), {
36
+ _id: false
37
+ })
38
+ };
39
+ }
40
+ return schema;
41
+ };
42
+ const buildSchema = (config, configFields, buildSchemaOptions = {})=>{
43
+ const { allowIDField, options } = buildSchemaOptions;
44
+ let fields = {};
45
+ let schemaFields = configFields;
46
+ if (!allowIDField) {
47
+ const idField = schemaFields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
48
+ if (idField) {
49
+ fields = {
50
+ _id: idField.type === 'number' ? Number : String
51
+ };
52
+ schemaFields = schemaFields.filter((field)=>!((0, _types.fieldAffectsData)(field) && field.name === 'id'));
53
+ }
54
+ }
55
+ const schema = new _mongoose.Schema(fields, options);
56
+ schemaFields.forEach((field)=>{
57
+ if (!(0, _types.fieldIsPresentationalOnly)(field)) {
58
+ const addFieldSchema = fieldToSchemaMap[field.type];
59
+ if (addFieldSchema) {
60
+ addFieldSchema(field, schema, config, buildSchemaOptions);
61
+ }
62
+ }
63
+ });
64
+ return schema;
65
+ };
66
+ const fieldToSchemaMap = {
67
+ array: (field, schema, config, buildSchemaOptions)=>{
68
+ const baseSchema = {
69
+ ...formatBaseSchema(field, buildSchemaOptions),
70
+ default: undefined,
71
+ type: [
72
+ buildSchema(config, field.fields, {
73
+ allowIDField: true,
74
+ disableUnique: buildSchemaOptions.disableUnique,
75
+ draftsEnabled: buildSchemaOptions.draftsEnabled,
76
+ options: {
77
+ _id: false,
78
+ id: false,
79
+ minimize: false
80
+ }
81
+ })
82
+ ]
83
+ };
84
+ schema.add({
85
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
86
+ });
87
+ },
88
+ blocks: (field, schema, config, buildSchemaOptions)=>{
89
+ const fieldSchema = {
90
+ default: undefined,
91
+ type: [
92
+ new _mongoose.Schema({}, {
93
+ _id: false,
94
+ discriminatorKey: 'blockType'
95
+ })
96
+ ]
97
+ };
98
+ schema.add({
99
+ [field.name]: localizeSchema(field, fieldSchema, config.localization)
100
+ });
101
+ field.blocks.forEach((blockItem)=>{
102
+ const blockSchema = new _mongoose.Schema({}, {
103
+ _id: false,
104
+ id: false
105
+ });
106
+ blockItem.fields.forEach((blockField)=>{
107
+ const addFieldSchema = fieldToSchemaMap[blockField.type];
108
+ if (addFieldSchema) {
109
+ addFieldSchema(blockField, blockSchema, config, buildSchemaOptions);
110
+ }
111
+ });
112
+ if (field.localized && config.localization) {
113
+ config.localization.localeCodes.forEach((localeCode)=>{
114
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
115
+ // @ts-ignore Possible incorrect typing in mongoose types, this works
116
+ schema.path(`${field.name}.${localeCode}`).discriminator(blockItem.slug, blockSchema);
117
+ });
118
+ } else {
119
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
120
+ // @ts-ignore Possible incorrect typing in mongoose types, this works
121
+ schema.path(field.name).discriminator(blockItem.slug, blockSchema);
122
+ }
123
+ });
124
+ },
125
+ checkbox: (field, schema, config, buildSchemaOptions)=>{
126
+ const baseSchema = {
127
+ ...formatBaseSchema(field, buildSchemaOptions),
128
+ type: Boolean
129
+ };
130
+ schema.add({
131
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
132
+ });
133
+ },
134
+ code: (field, schema, config, buildSchemaOptions)=>{
135
+ const baseSchema = {
136
+ ...formatBaseSchema(field, buildSchemaOptions),
137
+ type: String
138
+ };
139
+ schema.add({
140
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
141
+ });
142
+ },
143
+ collapsible: (field, schema, config, buildSchemaOptions)=>{
144
+ field.fields.forEach((subField)=>{
145
+ const addFieldSchema = fieldToSchemaMap[subField.type];
146
+ if (addFieldSchema) {
147
+ addFieldSchema(subField, schema, config, buildSchemaOptions);
148
+ }
149
+ });
150
+ },
151
+ date: (field, schema, config, buildSchemaOptions)=>{
152
+ const baseSchema = {
153
+ ...formatBaseSchema(field, buildSchemaOptions),
154
+ type: Date
155
+ };
156
+ schema.add({
157
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
158
+ });
159
+ },
160
+ email: (field, schema, config, buildSchemaOptions)=>{
161
+ const baseSchema = {
162
+ ...formatBaseSchema(field, buildSchemaOptions),
163
+ type: String
164
+ };
165
+ schema.add({
166
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
167
+ });
168
+ },
169
+ group: (field, schema, config, buildSchemaOptions)=>{
170
+ const formattedBaseSchema = formatBaseSchema(field, buildSchemaOptions);
171
+ // carry indexSortableFields through to versions if drafts enabled
172
+ const indexSortableFields = buildSchemaOptions.indexSortableFields && field.name === 'version' && buildSchemaOptions.draftsEnabled;
173
+ const baseSchema = {
174
+ ...formattedBaseSchema,
175
+ type: buildSchema(config, field.fields, {
176
+ disableUnique: buildSchemaOptions.disableUnique,
177
+ draftsEnabled: buildSchemaOptions.draftsEnabled,
178
+ indexSortableFields,
179
+ options: {
180
+ _id: false,
181
+ id: false,
182
+ minimize: false
183
+ }
184
+ })
185
+ };
186
+ schema.add({
187
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
188
+ });
189
+ },
190
+ json: (field, schema, config, buildSchemaOptions)=>{
191
+ const baseSchema = {
192
+ ...formatBaseSchema(field, buildSchemaOptions),
193
+ type: _mongoose.Schema.Types.Mixed
194
+ };
195
+ schema.add({
196
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
197
+ });
198
+ },
199
+ number: (field, schema, config, buildSchemaOptions)=>{
200
+ const baseSchema = {
201
+ ...formatBaseSchema(field, buildSchemaOptions),
202
+ type: field.hasMany ? [
203
+ Number
204
+ ] : Number
205
+ };
206
+ schema.add({
207
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
208
+ });
209
+ },
210
+ point: (field, schema, config, buildSchemaOptions)=>{
211
+ const baseSchema = {
212
+ coordinates: {
213
+ default: field.defaultValue || undefined,
214
+ required: false,
215
+ type: [
216
+ Number
217
+ ]
218
+ },
219
+ type: {
220
+ enum: [
221
+ 'Point'
222
+ ],
223
+ type: String
224
+ }
225
+ };
226
+ if (buildSchemaOptions.disableUnique && field.unique && field.localized) {
227
+ baseSchema.coordinates.sparse = true;
228
+ }
229
+ schema.add({
230
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
231
+ });
232
+ if (field.index === true || field.index === undefined) {
233
+ const indexOptions = {};
234
+ if (!buildSchemaOptions.disableUnique && field.unique) {
235
+ indexOptions.sparse = true;
236
+ indexOptions.unique = true;
237
+ }
238
+ if (field.localized && config.localization) {
239
+ config.localization.locales.forEach((locale)=>{
240
+ schema.index({
241
+ [`${field.name}.${locale}`]: '2dsphere'
242
+ }, indexOptions);
243
+ });
244
+ } else {
245
+ schema.index({
246
+ [field.name]: '2dsphere'
247
+ }, indexOptions);
248
+ }
249
+ }
250
+ },
251
+ radio: (field, schema, config, buildSchemaOptions)=>{
252
+ const baseSchema = {
253
+ ...formatBaseSchema(field, buildSchemaOptions),
254
+ enum: field.options.map((option)=>{
255
+ if (typeof option === 'object') return option.value;
256
+ return option;
257
+ }),
258
+ type: String
259
+ };
260
+ schema.add({
261
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
262
+ });
263
+ },
264
+ relationship: (field, schema, config, buildSchemaOptions)=>{
265
+ const hasManyRelations = Array.isArray(field.relationTo);
266
+ let schemaToReturn = {};
267
+ if (field.localized && config.localization) {
268
+ schemaToReturn = {
269
+ localized: true,
270
+ type: config.localization.localeCodes.reduce((locales, locale)=>{
271
+ let localeSchema = {};
272
+ if (hasManyRelations) {
273
+ localeSchema = {
274
+ ...formatBaseSchema(field, buildSchemaOptions),
275
+ _id: false,
276
+ relationTo: {
277
+ enum: field.relationTo,
278
+ type: String
279
+ },
280
+ type: _mongoose.Schema.Types.Mixed,
281
+ value: {
282
+ refPath: `${field.name}.${locale}.relationTo`,
283
+ type: _mongoose.Schema.Types.Mixed
284
+ }
285
+ };
286
+ } else {
287
+ localeSchema = {
288
+ ...formatBaseSchema(field, buildSchemaOptions),
289
+ ref: field.relationTo,
290
+ type: _mongoose.Schema.Types.Mixed
291
+ };
292
+ }
293
+ return {
294
+ ...locales,
295
+ [locale]: field.hasMany ? {
296
+ default: undefined,
297
+ type: [
298
+ localeSchema
299
+ ]
300
+ } : localeSchema
301
+ };
302
+ }, {})
303
+ };
304
+ } else if (hasManyRelations) {
305
+ schemaToReturn = {
306
+ ...formatBaseSchema(field, buildSchemaOptions),
307
+ _id: false,
308
+ relationTo: {
309
+ enum: field.relationTo,
310
+ type: String
311
+ },
312
+ type: _mongoose.Schema.Types.Mixed,
313
+ value: {
314
+ refPath: `${field.name}.relationTo`,
315
+ type: _mongoose.Schema.Types.Mixed
316
+ }
317
+ };
318
+ if (field.hasMany) {
319
+ schemaToReturn = {
320
+ default: undefined,
321
+ type: [
322
+ schemaToReturn
323
+ ]
324
+ };
325
+ }
326
+ } else {
327
+ schemaToReturn = {
328
+ ...formatBaseSchema(field, buildSchemaOptions),
329
+ ref: field.relationTo,
330
+ type: _mongoose.Schema.Types.Mixed
331
+ };
332
+ if (field.hasMany) {
333
+ schemaToReturn = {
334
+ default: undefined,
335
+ type: [
336
+ schemaToReturn
337
+ ]
338
+ };
339
+ }
340
+ }
341
+ schema.add({
342
+ [field.name]: schemaToReturn
343
+ });
344
+ },
345
+ richText: (field, schema, config, buildSchemaOptions)=>{
346
+ const baseSchema = {
347
+ ...formatBaseSchema(field, buildSchemaOptions),
348
+ type: _mongoose.Schema.Types.Mixed
349
+ };
350
+ schema.add({
351
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
352
+ });
353
+ },
354
+ row: (field, schema, config, buildSchemaOptions)=>{
355
+ field.fields.forEach((subField)=>{
356
+ const addFieldSchema = fieldToSchemaMap[subField.type];
357
+ if (addFieldSchema) {
358
+ addFieldSchema(subField, schema, config, buildSchemaOptions);
359
+ }
360
+ });
361
+ },
362
+ select: (field, schema, config, buildSchemaOptions)=>{
363
+ const baseSchema = {
364
+ ...formatBaseSchema(field, buildSchemaOptions),
365
+ enum: field.options.map((option)=>{
366
+ if (typeof option === 'object') return option.value;
367
+ return option;
368
+ }),
369
+ type: String
370
+ };
371
+ if (buildSchemaOptions.draftsEnabled || !field.required) {
372
+ baseSchema.enum.push(null);
373
+ }
374
+ schema.add({
375
+ [field.name]: localizeSchema(field, field.hasMany ? [
376
+ baseSchema
377
+ ] : baseSchema, config.localization)
378
+ });
379
+ },
380
+ tabs: (field, schema, config, buildSchemaOptions)=>{
381
+ field.tabs.forEach((tab)=>{
382
+ if ((0, _types.tabHasName)(tab)) {
383
+ const baseSchema = {
384
+ type: buildSchema(config, tab.fields, {
385
+ disableUnique: buildSchemaOptions.disableUnique,
386
+ draftsEnabled: buildSchemaOptions.draftsEnabled,
387
+ options: {
388
+ _id: false,
389
+ id: false,
390
+ minimize: false
391
+ }
392
+ })
393
+ };
394
+ schema.add({
395
+ [tab.name]: localizeSchema(tab, baseSchema, config.localization)
396
+ });
397
+ } else {
398
+ tab.fields.forEach((subField)=>{
399
+ const addFieldSchema = fieldToSchemaMap[subField.type];
400
+ if (addFieldSchema) {
401
+ addFieldSchema(subField, schema, config, buildSchemaOptions);
402
+ }
403
+ });
404
+ }
405
+ });
406
+ },
407
+ text: (field, schema, config, buildSchemaOptions)=>{
408
+ const baseSchema = {
409
+ ...formatBaseSchema(field, buildSchemaOptions),
410
+ type: String
411
+ };
412
+ schema.add({
413
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
414
+ });
415
+ },
416
+ textarea: (field, schema, config, buildSchemaOptions)=>{
417
+ const baseSchema = {
418
+ ...formatBaseSchema(field, buildSchemaOptions),
419
+ type: String
420
+ };
421
+ schema.add({
422
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
423
+ });
424
+ },
425
+ upload: (field, schema, config, buildSchemaOptions)=>{
426
+ const baseSchema = {
427
+ ...formatBaseSchema(field, buildSchemaOptions),
428
+ ref: field.relationTo,
429
+ type: _mongoose.Schema.Types.Mixed
430
+ };
431
+ schema.add({
432
+ [field.name]: localizeSchema(field, baseSchema, config.localization)
433
+ });
434
+ }
435
+ };
436
+ const _default = buildSchema;
437
+
438
+ //# 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  GroupField,\n  JSONField,\n  NumberField,\n  PointField,\n  RadioField,\n  RelationshipField,\n  RichTextField,\n  RowField,\n  SelectField,\n  TabsField,\n  TextField,\n  TextareaField,\n  UploadField,\n} from 'payload/types'\nimport type { FieldAffectingData, NonPresentationalField, Tab, UnnamedTab } 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 (schema.unique && (field.localized || draftsEnabled)) {\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      localized: true,\n      type: localization.localeCodes.reduce(\n        (localeSchema, locale) => ({\n          ...localeSchema,\n          [locale]: schema,\n        }),\n        {\n          _id: false,\n        },\n      ),\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      default: undefined,\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    }\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      default: undefined,\n      type: [new Schema({}, { _id: false, discriminatorKey: 'blockType' })],\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-ignore 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-ignore 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      coordinates: {\n        default: field.defaultValue || undefined,\n        required: false,\n        type: [Number],\n      },\n      type: {\n        enum: ['Point'],\n        type: String,\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}`]: '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      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n      type: String,\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        localized: true,\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              relationTo: { enum: field.relationTo, type: String },\n              type: Schema.Types.Mixed,\n              value: {\n                refPath: `${field.name}.${locale}.relationTo`,\n                type: Schema.Types.Mixed,\n              },\n            }\n          } else {\n            localeSchema = {\n              ...formatBaseSchema(field, buildSchemaOptions),\n              ref: field.relationTo,\n              type: Schema.Types.Mixed,\n            }\n          }\n\n          return {\n            ...locales,\n            [locale]: field.hasMany ? { default: undefined, type: [localeSchema] } : localeSchema,\n          }\n        }, {}),\n      }\n    } else if (hasManyRelations) {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        _id: false,\n        relationTo: { enum: field.relationTo, type: String },\n        type: Schema.Types.Mixed,\n        value: {\n          refPath: `${field.name}.relationTo`,\n          type: Schema.Types.Mixed,\n        },\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          default: undefined,\n          type: [schemaToReturn],\n        }\n      }\n    } else {\n      schemaToReturn = {\n        ...formatBaseSchema(field, buildSchemaOptions),\n        ref: field.relationTo,\n        type: Schema.Types.Mixed,\n      }\n\n      if (field.hasMany) {\n        schemaToReturn = {\n          default: undefined,\n          type: [schemaToReturn],\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      enum: field.options.map((option) => {\n        if (typeof option === 'object') return option.value\n        return option\n      }),\n      type: String,\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 = { ...formatBaseSchema(field, buildSchemaOptions), type: String }\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      ref: field.relationTo,\n      type: Schema.Types.Mixed,\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","sparse","hidden","localizeSchema","entity","localization","fieldIsLocalized","Array","isArray","locales","type","localeCodes","reduce","localeSchema","locale","_id","buildSchema","config","configFields","allowIDField","options","fields","schemaFields","idField","find","fieldAffectsData","name","Number","String","filter","Schema","forEach","fieldIsPresentationalOnly","addFieldSchema","fieldToSchemaMap","array","baseSchema","default","undefined","id","minimize","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","coordinates","defaultValue","enum","indexOptions","radio","map","option","value","relationship","hasManyRelations","relationTo","schemaToReturn","refPath","ref","richText","row","select","push","tabs","tab","tabHasName","text","textarea","upload"],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { Payload } from 'payload';
2
+ import type { Field, Where } from 'payload/types';
3
+ export declare function buildAndOrConditions({ collectionSlug, fields, globalSlug, locale, payload, where, }: {
4
+ collectionSlug?: string;
5
+ fields: Field[];
6
+ globalSlug?: string;
7
+ locale?: string;
8
+ payload: Payload;
9
+ where: Where[];
10
+ }): Promise<Record<string, unknown>[]>;
11
+ //# sourceMappingURL=buildAndOrConditions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildAndOrConditions.d.ts","sourceRoot":"","sources":["../../src/queries/buildAndOrConditions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAIjD,wBAAsB,oBAAoB,CAAC,EACzC,cAAc,EACd,MAAM,EACN,UAAU,EACV,MAAM,EACN,OAAO,EACP,KAAK,GACN,EAAE;IACD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,OAAO,CAAA;IAChB,KAAK,EAAE,KAAK,EAAE,CAAA;CACf,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAuBrC"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "buildAndOrConditions", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return buildAndOrConditions;
9
+ }
10
+ });
11
+ const _parseParams = require("./parseParams");
12
+ async function buildAndOrConditions({ collectionSlug, fields, globalSlug, locale, payload, where }) {
13
+ const completedConditions = [];
14
+ // Loop over all AND / OR operations and add them to the AND / OR query param
15
+ // Operations should come through as an array
16
+ // eslint-disable-next-line no-restricted-syntax
17
+ for (const condition of where){
18
+ // If the operation is properly formatted as an object
19
+ if (typeof condition === 'object') {
20
+ // eslint-disable-next-line no-await-in-loop
21
+ const result = await (0, _parseParams.parseParams)({
22
+ collectionSlug,
23
+ fields,
24
+ globalSlug,
25
+ locale,
26
+ payload,
27
+ where: condition
28
+ });
29
+ if (Object.keys(result).length > 0) {
30
+ completedConditions.push(result);
31
+ }
32
+ }
33
+ }
34
+ return completedConditions;
35
+ }
36
+
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL2J1aWxkQW5kT3JDb25kaXRpb25zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUGF5bG9hZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgdHlwZSB7IEZpZWxkLCBXaGVyZSB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IHBhcnNlUGFyYW1zIH0gZnJvbSAnLi9wYXJzZVBhcmFtcydcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQW5kT3JDb25kaXRpb25zKHtcbiAgY29sbGVjdGlvblNsdWcsXG4gIGZpZWxkcyxcbiAgZ2xvYmFsU2x1ZyxcbiAgbG9jYWxlLFxuICBwYXlsb2FkLFxuICB3aGVyZSxcbn06IHtcbiAgY29sbGVjdGlvblNsdWc/OiBzdHJpbmdcbiAgZmllbGRzOiBGaWVsZFtdXG4gIGdsb2JhbFNsdWc/OiBzdHJpbmdcbiAgbG9jYWxlPzogc3RyaW5nXG4gIHBheWxvYWQ6IFBheWxvYWRcbiAgd2hlcmU6IFdoZXJlW11cbn0pOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIHVua25vd24+W10+IHtcbiAgY29uc3QgY29tcGxldGVkQ29uZGl0aW9ucyA9IFtdXG4gIC8vIExvb3Agb3ZlciBhbGwgQU5EIC8gT1Igb3BlcmF0aW9ucyBhbmQgYWRkIHRoZW0gdG8gdGhlIEFORCAvIE9SIHF1ZXJ5IHBhcmFtXG4gIC8vIE9wZXJhdGlvbnMgc2hvdWxkIGNvbWUgdGhyb3VnaCBhcyBhbiBhcnJheVxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcmVzdHJpY3RlZC1zeW50YXhcbiAgZm9yIChjb25zdCBjb25kaXRpb24gb2Ygd2hlcmUpIHtcbiAgICAvLyBJZiB0aGUgb3BlcmF0aW9uIGlzIHByb3Blcmx5IGZvcm1hdHRlZCBhcyBhbiBvYmplY3RcbiAgICBpZiAodHlwZW9mIGNvbmRpdGlvbiA9PT0gJ29iamVjdCcpIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1hd2FpdC1pbi1sb29wXG4gICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBwYXJzZVBhcmFtcyh7XG4gICAgICAgIGNvbGxlY3Rpb25TbHVnLFxuICAgICAgICBmaWVsZHMsXG4gICAgICAgIGdsb2JhbFNsdWcsXG4gICAgICAgIGxvY2FsZSxcbiAgICAgICAgcGF5bG9hZCxcbiAgICAgICAgd2hlcmU6IGNvbmRpdGlvbixcbiAgICAgIH0pXG4gICAgICBpZiAoT2JqZWN0LmtleXMocmVzdWx0KS5sZW5ndGggPiAwKSB7XG4gICAgICAgIGNvbXBsZXRlZENvbmRpdGlvbnMucHVzaChyZXN1bHQpXG4gICAgICB9XG4gICAgfVxuICB9XG4gIHJldHVybiBjb21wbGV0ZWRDb25kaXRpb25zXG59XG4iXSwibmFtZXMiOlsiYnVpbGRBbmRPckNvbmRpdGlvbnMiLCJjb2xsZWN0aW9uU2x1ZyIsImZpZWxkcyIsImdsb2JhbFNsdWciLCJsb2NhbGUiLCJwYXlsb2FkIiwid2hlcmUiLCJjb21wbGV0ZWRDb25kaXRpb25zIiwiY29uZGl0aW9uIiwicmVzdWx0IiwicGFyc2VQYXJhbXMiLCJPYmplY3QiLCJrZXlzIiwibGVuZ3RoIiwicHVzaCJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFLc0JBOzs7ZUFBQUE7Ozs2QkFGTTtBQUVyQixlQUFlQSxxQkFBcUIsRUFDekNDLGNBQWMsRUFDZEMsTUFBTSxFQUNOQyxVQUFVLEVBQ1ZDLE1BQU0sRUFDTkMsT0FBTyxFQUNQQyxLQUFLLEVBUU47SUFDQyxNQUFNQyxzQkFBc0IsRUFBRTtJQUM5Qiw2RUFBNkU7SUFDN0UsNkNBQTZDO0lBQzdDLGdEQUFnRDtJQUNoRCxLQUFLLE1BQU1DLGFBQWFGLE1BQU87UUFDN0Isc0RBQXNEO1FBQ3RELElBQUksT0FBT0UsY0FBYyxVQUFVO1lBQ2pDLDRDQUE0QztZQUM1QyxNQUFNQyxTQUFTLE1BQU1DLElBQUFBLHdCQUFXLEVBQUM7Z0JBQy9CVDtnQkFDQUM7Z0JBQ0FDO2dCQUNBQztnQkFDQUM7Z0JBQ0FDLE9BQU9FO1lBQ1Q7WUFDQSxJQUFJRyxPQUFPQyxJQUFJLENBQUNILFFBQVFJLE1BQU0sR0FBRyxHQUFHO2dCQUNsQ04sb0JBQW9CTyxJQUFJLENBQUNMO1lBQzNCO1FBQ0Y7SUFDRjtJQUNBLE9BQU9GO0FBQ1QifQ==
@@ -0,0 +1,15 @@
1
+ import type { Payload } from 'payload';
2
+ import type { Field, Where } from 'payload/types';
3
+ type GetBuildQueryPluginArgs = {
4
+ collectionSlug?: string;
5
+ versionsFields?: Field[];
6
+ };
7
+ export type BuildQueryArgs = {
8
+ globalSlug?: string;
9
+ locale?: string;
10
+ payload: Payload;
11
+ where: Where;
12
+ };
13
+ declare const getBuildQueryPlugin: ({ collectionSlug, versionsFields }?: GetBuildQueryPluginArgs) => (schema: any) => void;
14
+ export default getBuildQueryPlugin;
15
+ //# sourceMappingURL=buildQuery.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildQuery.d.ts","sourceRoot":"","sources":["../../src/queries/buildQuery.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAMjD,KAAK,uBAAuB,GAAG;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,cAAc,CAAC,EAAE,KAAK,EAAE,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,OAAO,CAAA;IAChB,KAAK,EAAE,KAAK,CAAA;CACb,CAAA;AAID,QAAA,MAAM,mBAAmB,wCAAwC,uBAAuB,0BAsCvF,CAAA;AAED,eAAe,mBAAmB,CAAA"}