@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,49 @@
1
+ "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 _errors = require("payload/errors");
12
+ const _parseParams = require("./parseParams");
13
+ // This plugin asynchronously builds a list of Mongoose query constraints
14
+ // which can then be used in subsequent Mongoose queries.
15
+ const getBuildQueryPlugin = ({ collectionSlug, versionsFields } = {})=>{
16
+ return function buildQueryPlugin(schema) {
17
+ const modifiedSchema = schema;
18
+ async function buildQuery({ globalSlug, locale, payload, where }) {
19
+ let fields = versionsFields;
20
+ if (!fields) {
21
+ if (globalSlug) {
22
+ const globalConfig = payload.globals.config.find(({ slug })=>slug === globalSlug);
23
+ fields = globalConfig.fields;
24
+ }
25
+ if (collectionSlug) {
26
+ const collectionConfig = payload.collections[collectionSlug].config;
27
+ fields = collectionConfig.fields;
28
+ }
29
+ }
30
+ const errors = [];
31
+ const result = await (0, _parseParams.parseParams)({
32
+ collectionSlug,
33
+ fields,
34
+ globalSlug,
35
+ locale,
36
+ payload,
37
+ where
38
+ });
39
+ if (errors.length > 0) {
40
+ throw new _errors.QueryError(errors);
41
+ }
42
+ return result;
43
+ }
44
+ modifiedSchema.statics.buildQuery = buildQuery;
45
+ };
46
+ };
47
+ const _default = getBuildQueryPlugin;
48
+
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL2J1aWxkUXVlcnkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQYXlsb2FkIH0gZnJvbSAncGF5bG9hZCdcbmltcG9ydCB0eXBlIHsgRmllbGQsIFdoZXJlIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgUXVlcnlFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuXG5pbXBvcnQgeyBwYXJzZVBhcmFtcyB9IGZyb20gJy4vcGFyc2VQYXJhbXMnXG5cbnR5cGUgR2V0QnVpbGRRdWVyeVBsdWdpbkFyZ3MgPSB7XG4gIGNvbGxlY3Rpb25TbHVnPzogc3RyaW5nXG4gIHZlcnNpb25zRmllbGRzPzogRmllbGRbXVxufVxuXG5leHBvcnQgdHlwZSBCdWlsZFF1ZXJ5QXJncyA9IHtcbiAgZ2xvYmFsU2x1Zz86IHN0cmluZ1xuICBsb2NhbGU/OiBzdHJpbmdcbiAgcGF5bG9hZDogUGF5bG9hZFxuICB3aGVyZTogV2hlcmVcbn1cblxuLy8gVGhpcyBwbHVnaW4gYXN5bmNocm9ub3VzbHkgYnVpbGRzIGEgbGlzdCBvZiBNb25nb29zZSBxdWVyeSBjb25zdHJhaW50c1xuLy8gd2hpY2ggY2FuIHRoZW4gYmUgdXNlZCBpbiBzdWJzZXF1ZW50IE1vbmdvb3NlIHF1ZXJpZXMuXG5jb25zdCBnZXRCdWlsZFF1ZXJ5UGx1Z2luID0gKHsgY29sbGVjdGlvblNsdWcsIHZlcnNpb25zRmllbGRzIH06IEdldEJ1aWxkUXVlcnlQbHVnaW5BcmdzID0ge30pID0+IHtcbiAgcmV0dXJuIGZ1bmN0aW9uIGJ1aWxkUXVlcnlQbHVnaW4oc2NoZW1hKSB7XG4gICAgY29uc3QgbW9kaWZpZWRTY2hlbWEgPSBzY2hlbWFcbiAgICBhc3luYyBmdW5jdGlvbiBidWlsZFF1ZXJ5KHtcbiAgICAgIGdsb2JhbFNsdWcsXG4gICAgICBsb2NhbGUsXG4gICAgICBwYXlsb2FkLFxuICAgICAgd2hlcmUsXG4gICAgfTogQnVpbGRRdWVyeUFyZ3MpOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIHVua25vd24+PiB7XG4gICAgICBsZXQgZmllbGRzID0gdmVyc2lvbnNGaWVsZHNcbiAgICAgIGlmICghZmllbGRzKSB7XG4gICAgICAgIGlmIChnbG9iYWxTbHVnKSB7XG4gICAgICAgICAgY29uc3QgZ2xvYmFsQ29uZmlnID0gcGF5bG9hZC5nbG9iYWxzLmNvbmZpZy5maW5kKCh7IHNsdWcgfSkgPT4gc2x1ZyA9PT0gZ2xvYmFsU2x1ZylcbiAgICAgICAgICBmaWVsZHMgPSBnbG9iYWxDb25maWcuZmllbGRzXG4gICAgICAgIH1cbiAgICAgICAgaWYgKGNvbGxlY3Rpb25TbHVnKSB7XG4gICAgICAgICAgY29uc3QgY29sbGVjdGlvbkNvbmZpZyA9IHBheWxvYWQuY29sbGVjdGlvbnNbY29sbGVjdGlvblNsdWddLmNvbmZpZ1xuICAgICAgICAgIGZpZWxkcyA9IGNvbGxlY3Rpb25Db25maWcuZmllbGRzXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGNvbnN0IGVycm9ycyA9IFtdXG4gICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBwYXJzZVBhcmFtcyh7XG4gICAgICAgIGNvbGxlY3Rpb25TbHVnLFxuICAgICAgICBmaWVsZHMsXG4gICAgICAgIGdsb2JhbFNsdWcsXG4gICAgICAgIGxvY2FsZSxcbiAgICAgICAgcGF5bG9hZCxcbiAgICAgICAgd2hlcmUsXG4gICAgICB9KVxuXG4gICAgICBpZiAoZXJyb3JzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgdGhyb3cgbmV3IFF1ZXJ5RXJyb3IoZXJyb3JzKVxuICAgICAgfVxuXG4gICAgICByZXR1cm4gcmVzdWx0XG4gICAgfVxuICAgIG1vZGlmaWVkU2NoZW1hLnN0YXRpY3MuYnVpbGRRdWVyeSA9IGJ1aWxkUXVlcnlcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBnZXRCdWlsZFF1ZXJ5UGx1Z2luXG4iXSwibmFtZXMiOlsiZ2V0QnVpbGRRdWVyeVBsdWdpbiIsImNvbGxlY3Rpb25TbHVnIiwidmVyc2lvbnNGaWVsZHMiLCJidWlsZFF1ZXJ5UGx1Z2luIiwic2NoZW1hIiwibW9kaWZpZWRTY2hlbWEiLCJidWlsZFF1ZXJ5IiwiZ2xvYmFsU2x1ZyIsImxvY2FsZSIsInBheWxvYWQiLCJ3aGVyZSIsImZpZWxkcyIsImdsb2JhbENvbmZpZyIsImdsb2JhbHMiLCJjb25maWciLCJmaW5kIiwic2x1ZyIsImNvbGxlY3Rpb25Db25maWciLCJjb2xsZWN0aW9ucyIsImVycm9ycyIsInJlc3VsdCIsInBhcnNlUGFyYW1zIiwibGVuZ3RoIiwiUXVlcnlFcnJvciIsInN0YXRpY3MiXSwibWFwcGluZ3MiOiI7Ozs7K0JBNkRBOzs7ZUFBQTs7O3dCQTFEMkI7NkJBRUM7QUFjNUIseUVBQXlFO0FBQ3pFLHlEQUF5RDtBQUN6RCxNQUFNQSxzQkFBc0IsQ0FBQyxFQUFFQyxjQUFjLEVBQUVDLGNBQWMsRUFBMkIsR0FBRyxDQUFDLENBQUM7SUFDM0YsT0FBTyxTQUFTQyxpQkFBaUJDLE1BQU07UUFDckMsTUFBTUMsaUJBQWlCRDtRQUN2QixlQUFlRSxXQUFXLEVBQ3hCQyxVQUFVLEVBQ1ZDLE1BQU0sRUFDTkMsT0FBTyxFQUNQQyxLQUFLLEVBQ1U7WUFDZixJQUFJQyxTQUFTVDtZQUNiLElBQUksQ0FBQ1MsUUFBUTtnQkFDWCxJQUFJSixZQUFZO29CQUNkLE1BQU1LLGVBQWVILFFBQVFJLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxJQUFJLENBQUMsQ0FBQyxFQUFFQyxJQUFJLEVBQUUsR0FBS0EsU0FBU1Q7b0JBQ3hFSSxTQUFTQyxhQUFhRCxNQUFNO2dCQUM5QjtnQkFDQSxJQUFJVixnQkFBZ0I7b0JBQ2xCLE1BQU1nQixtQkFBbUJSLFFBQVFTLFdBQVcsQ0FBQ2pCLGVBQWUsQ0FBQ2EsTUFBTTtvQkFDbkVILFNBQVNNLGlCQUFpQk4sTUFBTTtnQkFDbEM7WUFDRjtZQUNBLE1BQU1RLFNBQVMsRUFBRTtZQUNqQixNQUFNQyxTQUFTLE1BQU1DLElBQUFBLHdCQUFXLEVBQUM7Z0JBQy9CcEI7Z0JBQ0FVO2dCQUNBSjtnQkFDQUM7Z0JBQ0FDO2dCQUNBQztZQUNGO1lBRUEsSUFBSVMsT0FBT0csTUFBTSxHQUFHLEdBQUc7Z0JBQ3JCLE1BQU0sSUFBSUMsa0JBQVUsQ0FBQ0o7WUFDdkI7WUFFQSxPQUFPQztRQUNUO1FBQ0FmLGVBQWVtQixPQUFPLENBQUNsQixVQUFVLEdBQUdBO0lBQ3RDO0FBQ0Y7TUFFQSxXQUFlTiJ9
@@ -0,0 +1,21 @@
1
+ import type { Payload } from 'payload';
2
+ import type { Field } from 'payload/types';
3
+ type SearchParam = {
4
+ path?: string;
5
+ value: unknown;
6
+ };
7
+ /**
8
+ * Convert the Payload key / value / operator into a MongoDB query
9
+ */
10
+ export declare function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPath, locale, operator, payload, val, }: {
11
+ collectionSlug?: string;
12
+ fields: Field[];
13
+ globalSlug?: string;
14
+ incomingPath: string;
15
+ locale?: string;
16
+ operator: string;
17
+ payload: Payload;
18
+ val: unknown;
19
+ }): Promise<SearchParam>;
20
+ export {};
21
+ //# sourceMappingURL=buildSearchParams.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildSearchParams.d.ts","sourceRoot":"","sources":["../../src/queries/buildSearchParams.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAc1C,KAAK,WAAW,GAAG;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAOD;;GAEG;AACH,wBAAsB,gBAAgB,CAAC,EACrC,cAAc,EACd,MAAM,EACN,UAAU,EACV,YAAY,EACZ,MAAM,EACN,QAAQ,EACR,OAAO,EACP,GAAG,GACJ,EAAE;IACD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,CAAA;IACpB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,OAAO,CAAA;IAChB,GAAG,EAAE,OAAO,CAAA;CACb,GAAG,OAAO,CAAC,WAAW,CAAC,CAuNvB"}
@@ -0,0 +1,219 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "buildSearchParam", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return buildSearchParam;
9
+ }
10
+ });
11
+ const _bsonobjectid = /*#__PURE__*/ _interop_require_default(require("bson-objectid"));
12
+ const _mongoose = /*#__PURE__*/ _interop_require_default(require("mongoose"));
13
+ const _database = require("payload/database");
14
+ const _types = require("payload/types");
15
+ const _operatorMap = require("./operatorMap");
16
+ const _sanitizeQueryValue = require("./sanitizeQueryValue");
17
+ function _interop_require_default(obj) {
18
+ return obj && obj.__esModule ? obj : {
19
+ default: obj
20
+ };
21
+ }
22
+ const subQueryOptions = {
23
+ lean: true,
24
+ limit: 50
25
+ };
26
+ async function buildSearchParam({ collectionSlug, fields, globalSlug, incomingPath, locale, operator, payload, val }) {
27
+ // Replace GraphQL nested field double underscore formatting
28
+ let sanitizedPath = incomingPath.replace(/__/g, '.');
29
+ if (sanitizedPath === 'id') sanitizedPath = '_id';
30
+ let paths = [];
31
+ let hasCustomID = false;
32
+ if (sanitizedPath === '_id') {
33
+ const customIDfield = payload.collections[collectionSlug]?.config.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === 'id');
34
+ let idFieldType = 'text';
35
+ if (customIDfield) {
36
+ if (customIDfield?.type === 'text' || customIDfield?.type === 'number') {
37
+ idFieldType = customIDfield.type;
38
+ }
39
+ hasCustomID = true;
40
+ }
41
+ paths.push({
42
+ collectionSlug,
43
+ complete: true,
44
+ field: {
45
+ name: 'id',
46
+ type: idFieldType
47
+ },
48
+ path: '_id'
49
+ });
50
+ } else {
51
+ paths = await (0, _database.getLocalizedPaths)({
52
+ collectionSlug,
53
+ fields,
54
+ globalSlug,
55
+ incomingPath: sanitizedPath,
56
+ locale,
57
+ payload
58
+ });
59
+ }
60
+ const [{ field, path }] = paths;
61
+ if (path) {
62
+ const formattedValue = (0, _sanitizeQueryValue.sanitizeQueryValue)({
63
+ field,
64
+ hasCustomID,
65
+ operator,
66
+ path,
67
+ val
68
+ });
69
+ // If there are multiple collections to search through,
70
+ // Recursively build up a list of query constraints
71
+ if (paths.length > 1) {
72
+ // Remove top collection and reverse array
73
+ // to work backwards from top
74
+ const pathsToQuery = paths.slice(1).reverse();
75
+ const initialRelationshipQuery = {
76
+ value: {}
77
+ };
78
+ const relationshipQuery = await pathsToQuery.reduce(async (priorQuery, { collectionSlug: slug, path: subPath }, i)=>{
79
+ const priorQueryResult = await priorQuery;
80
+ const SubModel = payload.db.collections[slug];
81
+ // On the "deepest" collection,
82
+ // Search on the value passed through the query
83
+ if (i === 0) {
84
+ const subQuery = await SubModel.buildQuery({
85
+ locale,
86
+ payload,
87
+ where: {
88
+ [subPath]: {
89
+ [operator]: val
90
+ }
91
+ }
92
+ });
93
+ const result = await SubModel.find(subQuery, subQueryOptions);
94
+ const $in = [];
95
+ result.forEach((doc)=>{
96
+ const stringID = doc._id.toString();
97
+ $in.push(stringID);
98
+ if (_mongoose.default.Types.ObjectId.isValid(stringID)) {
99
+ $in.push(doc._id);
100
+ }
101
+ });
102
+ if (pathsToQuery.length === 1) {
103
+ return {
104
+ path,
105
+ value: {
106
+ $in
107
+ }
108
+ };
109
+ }
110
+ const nextSubPath = pathsToQuery[i + 1].path;
111
+ return {
112
+ value: {
113
+ [nextSubPath]: {
114
+ $in
115
+ }
116
+ }
117
+ };
118
+ }
119
+ const subQuery = priorQueryResult.value;
120
+ const result = await SubModel.find(subQuery, subQueryOptions);
121
+ const $in = result.map((doc)=>doc._id.toString());
122
+ // If it is the last recursion
123
+ // then pass through the search param
124
+ if (i + 1 === pathsToQuery.length) {
125
+ return {
126
+ path,
127
+ value: {
128
+ $in
129
+ }
130
+ };
131
+ }
132
+ return {
133
+ value: {
134
+ _id: {
135
+ $in
136
+ }
137
+ }
138
+ };
139
+ }, Promise.resolve(initialRelationshipQuery));
140
+ return relationshipQuery;
141
+ }
142
+ if (operator && _types.validOperators.includes(operator)) {
143
+ const operatorKey = _operatorMap.operatorMap[operator];
144
+ if (field.type === 'relationship' || field.type === 'upload') {
145
+ let hasNumberIDRelation;
146
+ const result = {
147
+ value: {
148
+ $or: [
149
+ {
150
+ [path]: {
151
+ [operatorKey]: formattedValue
152
+ }
153
+ }
154
+ ]
155
+ }
156
+ };
157
+ if (typeof formattedValue === 'string') {
158
+ if (_mongoose.default.Types.ObjectId.isValid(formattedValue)) {
159
+ result.value.$or.push({
160
+ [path]: {
161
+ [operatorKey]: (0, _bsonobjectid.default)(formattedValue)
162
+ }
163
+ });
164
+ } else {
165
+ (Array.isArray(field.relationTo) ? field.relationTo : [
166
+ field.relationTo
167
+ ]).forEach((relationTo)=>{
168
+ const isRelatedToCustomNumberID = payload.collections[relationTo]?.config?.fields.find((relatedField)=>{
169
+ return (0, _types.fieldAffectsData)(relatedField) && relatedField.name === 'id' && relatedField.type === 'number';
170
+ });
171
+ if (isRelatedToCustomNumberID) {
172
+ if (isRelatedToCustomNumberID.type === 'number') hasNumberIDRelation = true;
173
+ }
174
+ });
175
+ if (hasNumberIDRelation) result.value.$or.push({
176
+ [path]: {
177
+ [operatorKey]: parseFloat(formattedValue)
178
+ }
179
+ });
180
+ }
181
+ }
182
+ if (result.value.$or.length > 1) {
183
+ return result;
184
+ }
185
+ }
186
+ if (operator === 'like' && typeof formattedValue === 'string') {
187
+ const words = formattedValue.split(' ');
188
+ const result = {
189
+ value: {
190
+ $and: words.map((word)=>({
191
+ [path]: {
192
+ $options: 'i',
193
+ $regex: word.replace(/[\\^$*+?.()|[\]{}]/g, '\\$&')
194
+ }
195
+ }))
196
+ }
197
+ };
198
+ return result;
199
+ }
200
+ // Some operators like 'near' need to define a full query
201
+ // so if there is no operator key, just return the value
202
+ if (!operatorKey) {
203
+ return {
204
+ path,
205
+ value: formattedValue
206
+ };
207
+ }
208
+ return {
209
+ path,
210
+ value: {
211
+ [operatorKey]: formattedValue
212
+ }
213
+ };
214
+ }
215
+ }
216
+ return undefined;
217
+ }
218
+
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/buildSearchParams.ts"],"sourcesContent":["import type { Payload } from 'payload'\nimport type { PathToQuery } from 'payload/database'\nimport type { Field } from 'payload/types'\nimport type { Operator } from 'payload/types'\n\nimport objectID from 'bson-objectid'\nimport mongoose from 'mongoose'\nimport { getLocalizedPaths } from 'payload/database'\nimport { fieldAffectsData } from 'payload/types'\nimport { validOperators } from 'payload/types'\n\nimport type { MongooseAdapter } from '..'\n\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype SearchParam = {\n  path?: string\n  value: unknown\n}\n\nconst subQueryOptions = {\n  lean: true,\n  limit: 50,\n}\n\n/**\n * Convert the Payload key / value / operator into a MongoDB query\n */\nexport async function buildSearchParam({\n  collectionSlug,\n  fields,\n  globalSlug,\n  incomingPath,\n  locale,\n  operator,\n  payload,\n  val,\n}: {\n  collectionSlug?: string\n  fields: Field[]\n  globalSlug?: string\n  incomingPath: string\n  locale?: string\n  operator: string\n  payload: Payload\n  val: unknown\n}): Promise<SearchParam> {\n  // Replace GraphQL nested field double underscore formatting\n  let sanitizedPath = incomingPath.replace(/__/g, '.')\n  if (sanitizedPath === 'id') sanitizedPath = '_id'\n\n  let paths: PathToQuery[] = []\n\n  let hasCustomID = false\n\n  if (sanitizedPath === '_id') {\n    const customIDfield = payload.collections[collectionSlug]?.config.fields.find(\n      (field) => fieldAffectsData(field) && field.name === 'id',\n    )\n\n    let idFieldType: 'number' | 'text' = 'text'\n\n    if (customIDfield) {\n      if (customIDfield?.type === 'text' || customIDfield?.type === 'number') {\n        idFieldType = customIDfield.type\n      }\n\n      hasCustomID = true\n    }\n\n    paths.push({\n      collectionSlug,\n      complete: true,\n      field: {\n        name: 'id',\n        type: idFieldType,\n      } as Field,\n      path: '_id',\n    })\n  } else {\n    paths = await getLocalizedPaths({\n      collectionSlug,\n      fields,\n      globalSlug,\n      incomingPath: sanitizedPath,\n      locale,\n      payload,\n    })\n  }\n\n  const [{ field, path }] = paths\n\n  if (path) {\n    const formattedValue = sanitizeQueryValue({\n      field,\n      hasCustomID,\n      operator,\n      path,\n      val,\n    })\n\n    // If there are multiple collections to search through,\n    // Recursively build up a list of query constraints\n    if (paths.length > 1) {\n      // Remove top collection and reverse array\n      // to work backwards from top\n      const pathsToQuery = paths.slice(1).reverse()\n\n      const initialRelationshipQuery = {\n        value: {},\n      } as SearchParam\n\n      const relationshipQuery = await pathsToQuery.reduce(\n        async (priorQuery, { collectionSlug: slug, path: subPath }, i) => {\n          const priorQueryResult = await priorQuery\n\n          const SubModel = (payload.db as MongooseAdapter).collections[slug]\n\n          // On the \"deepest\" collection,\n          // Search on the value passed through the query\n          if (i === 0) {\n            const subQuery = await SubModel.buildQuery({\n              locale,\n              payload,\n              where: {\n                [subPath]: {\n                  [operator]: val,\n                },\n              },\n            })\n\n            const result = await SubModel.find(subQuery, subQueryOptions)\n\n            const $in: unknown[] = []\n\n            result.forEach((doc) => {\n              const stringID = doc._id.toString()\n              $in.push(stringID)\n\n              if (mongoose.Types.ObjectId.isValid(stringID)) {\n                $in.push(doc._id)\n              }\n            })\n\n            if (pathsToQuery.length === 1) {\n              return {\n                path,\n                value: { $in },\n              }\n            }\n\n            const nextSubPath = pathsToQuery[i + 1].path\n\n            return {\n              value: { [nextSubPath]: { $in } },\n            }\n          }\n\n          const subQuery = priorQueryResult.value\n          const result = await SubModel.find(subQuery, subQueryOptions)\n\n          const $in = result.map((doc) => doc._id.toString())\n\n          // If it is the last recursion\n          // then pass through the search param\n          if (i + 1 === pathsToQuery.length) {\n            return {\n              path,\n              value: { $in },\n            }\n          }\n\n          return {\n            value: {\n              _id: { $in },\n            },\n          }\n        },\n        Promise.resolve(initialRelationshipQuery),\n      )\n\n      return relationshipQuery\n    }\n\n    if (operator && validOperators.includes(operator as Operator)) {\n      const operatorKey = operatorMap[operator]\n\n      if (field.type === 'relationship' || field.type === 'upload') {\n        let hasNumberIDRelation\n\n        const result = {\n          value: {\n            $or: [{ [path]: { [operatorKey]: formattedValue } }],\n          },\n        }\n\n        if (typeof formattedValue === 'string') {\n          if (mongoose.Types.ObjectId.isValid(formattedValue)) {\n            result.value.$or.push({ [path]: { [operatorKey]: objectID(formattedValue) } })\n          } else {\n            ;(Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]).forEach(\n              (relationTo) => {\n                const isRelatedToCustomNumberID = payload.collections[\n                  relationTo\n                ]?.config?.fields.find((relatedField) => {\n                  return (\n                    fieldAffectsData(relatedField) &&\n                    relatedField.name === 'id' &&\n                    relatedField.type === 'number'\n                  )\n                })\n\n                if (isRelatedToCustomNumberID) {\n                  if (isRelatedToCustomNumberID.type === 'number') hasNumberIDRelation = true\n                }\n              },\n            )\n\n            if (hasNumberIDRelation)\n              result.value.$or.push({ [path]: { [operatorKey]: parseFloat(formattedValue) } })\n          }\n        }\n\n        if (result.value.$or.length > 1) {\n          return result\n        }\n      }\n\n      if (operator === 'like' && typeof formattedValue === 'string') {\n        const words = formattedValue.split(' ')\n\n        const result = {\n          value: {\n            $and: words.map((word) => ({\n              [path]: {\n                $options: 'i',\n                $regex: word.replace(/[\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'),\n              },\n            })),\n          },\n        }\n\n        return result\n      }\n\n      // Some operators like 'near' need to define a full query\n      // so if there is no operator key, just return the value\n      if (!operatorKey) {\n        return {\n          path,\n          value: formattedValue,\n        }\n      }\n\n      return {\n        path,\n        value: { [operatorKey]: formattedValue },\n      }\n    }\n  }\n  return undefined\n}\n"],"names":["buildSearchParam","subQueryOptions","lean","limit","collectionSlug","fields","globalSlug","incomingPath","locale","operator","payload","val","sanitizedPath","replace","paths","hasCustomID","customIDfield","collections","config","find","field","fieldAffectsData","name","idFieldType","type","push","complete","path","getLocalizedPaths","formattedValue","sanitizeQueryValue","length","pathsToQuery","slice","reverse","initialRelationshipQuery","value","relationshipQuery","reduce","priorQuery","slug","subPath","i","priorQueryResult","SubModel","db","subQuery","buildQuery","where","result","$in","forEach","doc","stringID","_id","toString","mongoose","Types","ObjectId","isValid","nextSubPath","map","Promise","resolve","validOperators","includes","operatorKey","operatorMap","hasNumberIDRelation","$or","objectID","Array","isArray","relationTo","isRelatedToCustomNumberID","relatedField","parseFloat","words","split","$and","word","$options","$regex","undefined"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import type { PaginateOptions } from 'mongoose';
2
+ import type { SanitizedConfig } from 'payload/config';
3
+ import type { Field } from 'payload/types';
4
+ type Args = {
5
+ config: SanitizedConfig;
6
+ fields: Field[];
7
+ locale: string;
8
+ sort: string;
9
+ timestamps: boolean;
10
+ };
11
+ export type SortArgs = {
12
+ direction: SortDirection;
13
+ property: string;
14
+ }[];
15
+ export type SortDirection = 'asc' | 'desc';
16
+ export declare const buildSortParam: ({ config, fields, locale, sort, timestamps, }: Args) => PaginateOptions['sort'];
17
+ export {};
18
+ //# sourceMappingURL=buildSortParam.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildSortParam.d.ts","sourceRoot":"","sources":["../../src/queries/buildSortParam.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC/C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAI1C,KAAK,IAAI,GAAG;IACV,MAAM,EAAE,eAAe,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,SAAS,EAAE,aAAa,CAAA;IACxB,QAAQ,EAAE,MAAM,CAAA;CACjB,EAAE,CAAA;AAEH,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAA;AAE1C,eAAO,MAAM,cAAc,kDAMxB,IAAI,KAAG,eAAe,CAAC,MAAM,CA6B/B,CAAA"}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "buildSortParam", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return buildSortParam;
9
+ }
10
+ });
11
+ const _getLocalizedSortProperty = require("./getLocalizedSortProperty");
12
+ const buildSortParam = ({ config, fields, locale, sort, timestamps })=>{
13
+ let sortProperty;
14
+ let sortDirection = 'desc';
15
+ if (!sort) {
16
+ if (timestamps) {
17
+ sortProperty = 'createdAt';
18
+ } else {
19
+ sortProperty = '_id';
20
+ }
21
+ } else if (sort.indexOf('-') === 0) {
22
+ sortProperty = sort.substring(1);
23
+ } else {
24
+ sortProperty = sort;
25
+ sortDirection = 'asc';
26
+ }
27
+ if (sortProperty === 'id') {
28
+ sortProperty = '_id';
29
+ } else {
30
+ sortProperty = (0, _getLocalizedSortProperty.getLocalizedSortProperty)({
31
+ config,
32
+ fields,
33
+ locale,
34
+ segments: sortProperty.split('.')
35
+ });
36
+ }
37
+ return {
38
+ [sortProperty]: sortDirection
39
+ };
40
+ };
41
+
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL2J1aWxkU29ydFBhcmFtLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUGFnaW5hdGVPcHRpb25zIH0gZnJvbSAnbW9uZ29vc2UnXG5pbXBvcnQgdHlwZSB7IFNhbml0aXplZENvbmZpZyB9IGZyb20gJ3BheWxvYWQvY29uZmlnJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IGdldExvY2FsaXplZFNvcnRQcm9wZXJ0eSB9IGZyb20gJy4vZ2V0TG9jYWxpemVkU29ydFByb3BlcnR5J1xuXG50eXBlIEFyZ3MgPSB7XG4gIGNvbmZpZzogU2FuaXRpemVkQ29uZmlnXG4gIGZpZWxkczogRmllbGRbXVxuICBsb2NhbGU6IHN0cmluZ1xuICBzb3J0OiBzdHJpbmdcbiAgdGltZXN0YW1wczogYm9vbGVhblxufVxuXG5leHBvcnQgdHlwZSBTb3J0QXJncyA9IHtcbiAgZGlyZWN0aW9uOiBTb3J0RGlyZWN0aW9uXG4gIHByb3BlcnR5OiBzdHJpbmdcbn1bXVxuXG5leHBvcnQgdHlwZSBTb3J0RGlyZWN0aW9uID0gJ2FzYycgfCAnZGVzYydcblxuZXhwb3J0IGNvbnN0IGJ1aWxkU29ydFBhcmFtID0gKHtcbiAgY29uZmlnLFxuICBmaWVsZHMsXG4gIGxvY2FsZSxcbiAgc29ydCxcbiAgdGltZXN0YW1wcyxcbn06IEFyZ3MpOiBQYWdpbmF0ZU9wdGlvbnNbJ3NvcnQnXSA9PiB7XG4gIGxldCBzb3J0UHJvcGVydHk6IHN0cmluZ1xuICBsZXQgc29ydERpcmVjdGlvbjogU29ydERpcmVjdGlvbiA9ICdkZXNjJ1xuXG4gIGlmICghc29ydCkge1xuICAgIGlmICh0aW1lc3RhbXBzKSB7XG4gICAgICBzb3J0UHJvcGVydHkgPSAnY3JlYXRlZEF0J1xuICAgIH0gZWxzZSB7XG4gICAgICBzb3J0UHJvcGVydHkgPSAnX2lkJ1xuICAgIH1cbiAgfSBlbHNlIGlmIChzb3J0LmluZGV4T2YoJy0nKSA9PT0gMCkge1xuICAgIHNvcnRQcm9wZXJ0eSA9IHNvcnQuc3Vic3RyaW5nKDEpXG4gIH0gZWxzZSB7XG4gICAgc29ydFByb3BlcnR5ID0gc29ydFxuICAgIHNvcnREaXJlY3Rpb24gPSAnYXNjJ1xuICB9XG5cbiAgaWYgKHNvcnRQcm9wZXJ0eSA9PT0gJ2lkJykge1xuICAgIHNvcnRQcm9wZXJ0eSA9ICdfaWQnXG4gIH0gZWxzZSB7XG4gICAgc29ydFByb3BlcnR5ID0gZ2V0TG9jYWxpemVkU29ydFByb3BlcnR5KHtcbiAgICAgIGNvbmZpZyxcbiAgICAgIGZpZWxkcyxcbiAgICAgIGxvY2FsZSxcbiAgICAgIHNlZ21lbnRzOiBzb3J0UHJvcGVydHkuc3BsaXQoJy4nKSxcbiAgICB9KVxuICB9XG5cbiAgcmV0dXJuIHsgW3NvcnRQcm9wZXJ0eV06IHNvcnREaXJlY3Rpb24gfVxufVxuIl0sIm5hbWVzIjpbImJ1aWxkU29ydFBhcmFtIiwiY29uZmlnIiwiZmllbGRzIiwibG9jYWxlIiwic29ydCIsInRpbWVzdGFtcHMiLCJzb3J0UHJvcGVydHkiLCJzb3J0RGlyZWN0aW9uIiwiaW5kZXhPZiIsInN1YnN0cmluZyIsImdldExvY2FsaXplZFNvcnRQcm9wZXJ0eSIsInNlZ21lbnRzIiwic3BsaXQiXSwibWFwcGluZ3MiOiI7Ozs7K0JBcUJhQTs7O2VBQUFBOzs7MENBakI0QjtBQWlCbEMsTUFBTUEsaUJBQWlCLENBQUMsRUFDN0JDLE1BQU0sRUFDTkMsTUFBTSxFQUNOQyxNQUFNLEVBQ05DLElBQUksRUFDSkMsVUFBVSxFQUNMO0lBQ0wsSUFBSUM7SUFDSixJQUFJQyxnQkFBK0I7SUFFbkMsSUFBSSxDQUFDSCxNQUFNO1FBQ1QsSUFBSUMsWUFBWTtZQUNkQyxlQUFlO1FBQ2pCLE9BQU87WUFDTEEsZUFBZTtRQUNqQjtJQUNGLE9BQU8sSUFBSUYsS0FBS0ksT0FBTyxDQUFDLFNBQVMsR0FBRztRQUNsQ0YsZUFBZUYsS0FBS0ssU0FBUyxDQUFDO0lBQ2hDLE9BQU87UUFDTEgsZUFBZUY7UUFDZkcsZ0JBQWdCO0lBQ2xCO0lBRUEsSUFBSUQsaUJBQWlCLE1BQU07UUFDekJBLGVBQWU7SUFDakIsT0FBTztRQUNMQSxlQUFlSSxJQUFBQSxrREFBd0IsRUFBQztZQUN0Q1Q7WUFDQUM7WUFDQUM7WUFDQVEsVUFBVUwsYUFBYU0sS0FBSyxDQUFDO1FBQy9CO0lBQ0Y7SUFFQSxPQUFPO1FBQUUsQ0FBQ04sYUFBYSxFQUFFQztJQUFjO0FBQ3pDIn0=
@@ -0,0 +1,12 @@
1
+ import type { SanitizedConfig } from 'payload/config';
2
+ import type { Field } from 'payload/types';
3
+ type Args = {
4
+ config: SanitizedConfig;
5
+ fields: Field[];
6
+ locale: string;
7
+ result?: string;
8
+ segments: string[];
9
+ };
10
+ export declare const getLocalizedSortProperty: ({ config, fields: incomingFields, locale, result: incomingResult, segments: incomingSegments, }: Args) => string;
11
+ export {};
12
+ //# sourceMappingURL=getLocalizedSortProperty.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getLocalizedSortProperty.d.ts","sourceRoot":"","sources":["../../src/queries/getLocalizedSortProperty.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAK1C,KAAK,IAAI,GAAG;IACV,MAAM,EAAE,eAAe,CAAA;IACvB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,EAAE,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,wBAAwB,oGAMlC,IAAI,KAAG,MAkFT,CAAA"}
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "getLocalizedSortProperty", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return getLocalizedSortProperty;
9
+ }
10
+ });
11
+ const _types = require("payload/types");
12
+ const _utilities = require("payload/utilities");
13
+ const getLocalizedSortProperty = ({ config, fields: incomingFields, locale, result: incomingResult, segments: incomingSegments })=>{
14
+ // If localization is not enabled, accept exactly
15
+ // what is sent in
16
+ if (!config.localization) {
17
+ return incomingSegments.join('.');
18
+ }
19
+ // Flatten incoming fields (row, etc)
20
+ const fields = (0, _utilities.flattenTopLevelFields)(incomingFields);
21
+ const segments = [
22
+ ...incomingSegments
23
+ ];
24
+ // Retrieve first segment, and remove from segments
25
+ const firstSegment = segments.shift();
26
+ // Attempt to find a matched field
27
+ const matchedField = fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === firstSegment);
28
+ if (matchedField && !(0, _types.fieldIsPresentationalOnly)(matchedField)) {
29
+ let nextFields;
30
+ const remainingSegments = [
31
+ ...segments
32
+ ];
33
+ let localizedSegment = matchedField.name;
34
+ if (matchedField.localized) {
35
+ // Check to see if next segment is a locale
36
+ if (segments.length > 0) {
37
+ const nextSegmentIsLocale = config.localization.localeCodes.includes(remainingSegments[0]);
38
+ // If next segment is locale, remove it from remaining segments
39
+ // and use it to localize the current segment
40
+ if (nextSegmentIsLocale) {
41
+ const nextSegment = remainingSegments.shift();
42
+ localizedSegment = `${matchedField.name}.${nextSegment}`;
43
+ }
44
+ } else {
45
+ // If no more segments, but field is localized, use default locale
46
+ localizedSegment = `${matchedField.name}.${locale}`;
47
+ }
48
+ }
49
+ // If there are subfields, pass them through
50
+ if (matchedField.type === 'tab' || matchedField.type === 'group' || matchedField.type === 'array') {
51
+ nextFields = matchedField.fields;
52
+ }
53
+ if (matchedField.type === 'blocks') {
54
+ nextFields = matchedField.blocks.reduce((flattenedBlockFields, block)=>{
55
+ return [
56
+ ...flattenedBlockFields,
57
+ ...block.fields.filter((blockField)=>(0, _types.fieldAffectsData)(blockField) && blockField.name !== 'blockType' && blockField.name !== 'blockName' || !(0, _types.fieldAffectsData)(blockField))
58
+ ];
59
+ }, []);
60
+ }
61
+ const result = incomingResult ? `${incomingResult}.${localizedSegment}` : localizedSegment;
62
+ if (nextFields) {
63
+ return getLocalizedSortProperty({
64
+ config,
65
+ fields: nextFields,
66
+ locale,
67
+ result,
68
+ segments: remainingSegments
69
+ });
70
+ }
71
+ return result;
72
+ }
73
+ return incomingSegments.join('.');
74
+ };
75
+
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL2dldExvY2FsaXplZFNvcnRQcm9wZXJ0eS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFNhbml0aXplZENvbmZpZyB9IGZyb20gJ3BheWxvYWQvY29uZmlnJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IGZpZWxkQWZmZWN0c0RhdGEsIGZpZWxkSXNQcmVzZW50YXRpb25hbE9ubHkgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuaW1wb3J0IHsgZmxhdHRlblRvcExldmVsRmllbGRzIH0gZnJvbSAncGF5bG9hZC91dGlsaXRpZXMnXG5cbnR5cGUgQXJncyA9IHtcbiAgY29uZmlnOiBTYW5pdGl6ZWRDb25maWdcbiAgZmllbGRzOiBGaWVsZFtdXG4gIGxvY2FsZTogc3RyaW5nXG4gIHJlc3VsdD86IHN0cmluZ1xuICBzZWdtZW50czogc3RyaW5nW11cbn1cblxuZXhwb3J0IGNvbnN0IGdldExvY2FsaXplZFNvcnRQcm9wZXJ0eSA9ICh7XG4gIGNvbmZpZyxcbiAgZmllbGRzOiBpbmNvbWluZ0ZpZWxkcyxcbiAgbG9jYWxlLFxuICByZXN1bHQ6IGluY29taW5nUmVzdWx0LFxuICBzZWdtZW50czogaW5jb21pbmdTZWdtZW50cyxcbn06IEFyZ3MpOiBzdHJpbmcgPT4ge1xuICAvLyBJZiBsb2NhbGl6YXRpb24gaXMgbm90IGVuYWJsZWQsIGFjY2VwdCBleGFjdGx5XG4gIC8vIHdoYXQgaXMgc2VudCBpblxuICBpZiAoIWNvbmZpZy5sb2NhbGl6YXRpb24pIHtcbiAgICByZXR1cm4gaW5jb21pbmdTZWdtZW50cy5qb2luKCcuJylcbiAgfVxuXG4gIC8vIEZsYXR0ZW4gaW5jb21pbmcgZmllbGRzIChyb3csIGV0YylcbiAgY29uc3QgZmllbGRzID0gZmxhdHRlblRvcExldmVsRmllbGRzKGluY29taW5nRmllbGRzKVxuXG4gIGNvbnN0IHNlZ21lbnRzID0gWy4uLmluY29taW5nU2VnbWVudHNdXG5cbiAgLy8gUmV0cmlldmUgZmlyc3Qgc2VnbWVudCwgYW5kIHJlbW92ZSBmcm9tIHNlZ21lbnRzXG4gIGNvbnN0IGZpcnN0U2VnbWVudCA9IHNlZ21lbnRzLnNoaWZ0KClcblxuICAvLyBBdHRlbXB0IHRvIGZpbmQgYSBtYXRjaGVkIGZpZWxkXG4gIGNvbnN0IG1hdGNoZWRGaWVsZCA9IGZpZWxkcy5maW5kKFxuICAgIChmaWVsZCkgPT4gZmllbGRBZmZlY3RzRGF0YShmaWVsZCkgJiYgZmllbGQubmFtZSA9PT0gZmlyc3RTZWdtZW50LFxuICApXG5cbiAgaWYgKG1hdGNoZWRGaWVsZCAmJiAhZmllbGRJc1ByZXNlbnRhdGlvbmFsT25seShtYXRjaGVkRmllbGQpKSB7XG4gICAgbGV0IG5leHRGaWVsZHM6IEZpZWxkW11cbiAgICBjb25zdCByZW1haW5pbmdTZWdtZW50cyA9IFsuLi5zZWdtZW50c11cbiAgICBsZXQgbG9jYWxpemVkU2VnbWVudCA9IG1hdGNoZWRGaWVsZC5uYW1lXG5cbiAgICBpZiAobWF0Y2hlZEZpZWxkLmxvY2FsaXplZCkge1xuICAgICAgLy8gQ2hlY2sgdG8gc2VlIGlmIG5leHQgc2VnbWVudCBpcyBhIGxvY2FsZVxuICAgICAgaWYgKHNlZ21lbnRzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgY29uc3QgbmV4dFNlZ21lbnRJc0xvY2FsZSA9IGNvbmZpZy5sb2NhbGl6YXRpb24ubG9jYWxlQ29kZXMuaW5jbHVkZXMocmVtYWluaW5nU2VnbWVudHNbMF0pXG5cbiAgICAgICAgLy8gSWYgbmV4dCBzZWdtZW50IGlzIGxvY2FsZSwgcmVtb3ZlIGl0IGZyb20gcmVtYWluaW5nIHNlZ21lbnRzXG4gICAgICAgIC8vIGFuZCB1c2UgaXQgdG8gbG9jYWxpemUgdGhlIGN1cnJlbnQgc2VnbWVudFxuICAgICAgICBpZiAobmV4dFNlZ21lbnRJc0xvY2FsZSkge1xuICAgICAgICAgIGNvbnN0IG5leHRTZWdtZW50ID0gcmVtYWluaW5nU2VnbWVudHMuc2hpZnQoKVxuICAgICAgICAgIGxvY2FsaXplZFNlZ21lbnQgPSBgJHttYXRjaGVkRmllbGQubmFtZX0uJHtuZXh0U2VnbWVudH1gXG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIElmIG5vIG1vcmUgc2VnbWVudHMsIGJ1dCBmaWVsZCBpcyBsb2NhbGl6ZWQsIHVzZSBkZWZhdWx0IGxvY2FsZVxuICAgICAgICBsb2NhbGl6ZWRTZWdtZW50ID0gYCR7bWF0Y2hlZEZpZWxkLm5hbWV9LiR7bG9jYWxlfWBcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBJZiB0aGVyZSBhcmUgc3ViZmllbGRzLCBwYXNzIHRoZW0gdGhyb3VnaFxuICAgIGlmIChcbiAgICAgIG1hdGNoZWRGaWVsZC50eXBlID09PSAndGFiJyB8fFxuICAgICAgbWF0Y2hlZEZpZWxkLnR5cGUgPT09ICdncm91cCcgfHxcbiAgICAgIG1hdGNoZWRGaWVsZC50eXBlID09PSAnYXJyYXknXG4gICAgKSB7XG4gICAgICBuZXh0RmllbGRzID0gbWF0Y2hlZEZpZWxkLmZpZWxkc1xuICAgIH1cblxuICAgIGlmIChtYXRjaGVkRmllbGQudHlwZSA9PT0gJ2Jsb2NrcycpIHtcbiAgICAgIG5leHRGaWVsZHMgPSBtYXRjaGVkRmllbGQuYmxvY2tzLnJlZHVjZSgoZmxhdHRlbmVkQmxvY2tGaWVsZHMsIGJsb2NrKSA9PiB7XG4gICAgICAgIHJldHVybiBbXG4gICAgICAgICAgLi4uZmxhdHRlbmVkQmxvY2tGaWVsZHMsXG4gICAgICAgICAgLi4uYmxvY2suZmllbGRzLmZpbHRlcihcbiAgICAgICAgICAgIChibG9ja0ZpZWxkKSA9PlxuICAgICAgICAgICAgICAoZmllbGRBZmZlY3RzRGF0YShibG9ja0ZpZWxkKSAmJlxuICAgICAgICAgICAgICAgIGJsb2NrRmllbGQubmFtZSAhPT0gJ2Jsb2NrVHlwZScgJiZcbiAgICAgICAgICAgICAgICBibG9ja0ZpZWxkLm5hbWUgIT09ICdibG9ja05hbWUnKSB8fFxuICAgICAgICAgICAgICAhZmllbGRBZmZlY3RzRGF0YShibG9ja0ZpZWxkKSxcbiAgICAgICAgICApLFxuICAgICAgICBdXG4gICAgICB9LCBbXSlcbiAgICB9XG5cbiAgICBjb25zdCByZXN1bHQgPSBpbmNvbWluZ1Jlc3VsdCA/IGAke2luY29taW5nUmVzdWx0fS4ke2xvY2FsaXplZFNlZ21lbnR9YCA6IGxvY2FsaXplZFNlZ21lbnRcblxuICAgIGlmIChuZXh0RmllbGRzKSB7XG4gICAgICByZXR1cm4gZ2V0TG9jYWxpemVkU29ydFByb3BlcnR5KHtcbiAgICAgICAgY29uZmlnLFxuICAgICAgICBmaWVsZHM6IG5leHRGaWVsZHMsXG4gICAgICAgIGxvY2FsZSxcbiAgICAgICAgcmVzdWx0LFxuICAgICAgICBzZWdtZW50czogcmVtYWluaW5nU2VnbWVudHMsXG4gICAgICB9KVxuICAgIH1cblxuICAgIHJldHVybiByZXN1bHRcbiAgfVxuXG4gIHJldHVybiBpbmNvbWluZ1NlZ21lbnRzLmpvaW4oJy4nKVxufVxuIl0sIm5hbWVzIjpbImdldExvY2FsaXplZFNvcnRQcm9wZXJ0eSIsImNvbmZpZyIsImZpZWxkcyIsImluY29taW5nRmllbGRzIiwibG9jYWxlIiwicmVzdWx0IiwiaW5jb21pbmdSZXN1bHQiLCJzZWdtZW50cyIsImluY29taW5nU2VnbWVudHMiLCJsb2NhbGl6YXRpb24iLCJqb2luIiwiZmxhdHRlblRvcExldmVsRmllbGRzIiwiZmlyc3RTZWdtZW50Iiwic2hpZnQiLCJtYXRjaGVkRmllbGQiLCJmaW5kIiwiZmllbGQiLCJmaWVsZEFmZmVjdHNEYXRhIiwibmFtZSIsImZpZWxkSXNQcmVzZW50YXRpb25hbE9ubHkiLCJuZXh0RmllbGRzIiwicmVtYWluaW5nU2VnbWVudHMiLCJsb2NhbGl6ZWRTZWdtZW50IiwibG9jYWxpemVkIiwibGVuZ3RoIiwibmV4dFNlZ21lbnRJc0xvY2FsZSIsImxvY2FsZUNvZGVzIiwiaW5jbHVkZXMiLCJuZXh0U2VnbWVudCIsInR5cGUiLCJibG9ja3MiLCJyZWR1Y2UiLCJm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