@payloadcms/db-postgres 0.3.1 → 0.5.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -162,6 +162,14 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
162
162
  NULL`);
163
163
  break;
164
164
  }
165
+ if (operator === 'equals' && queryValue === null) {
166
+ constraints.push((0, _drizzleorm.isNull)(rawColumn || table[columnName]));
167
+ break;
168
+ }
169
+ if (operator === 'not_equals' && queryValue === null) {
170
+ constraints.push((0, _drizzleorm.isNotNull)(rawColumn || table[columnName]));
171
+ break;
172
+ }
165
173
  constraints.push(_operatorMap.operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
166
174
  }
167
175
  }
@@ -183,4 +191,4 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
183
191
  return result;
184
192
  }
185
193
 
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (\n                  ['json', 'richText'].includes(field.type) &&\n                  Array.isArray(pathSegments) &&\n                  pathSegments.length > 1\n                ) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                    break\n                  }\n\n                  const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                  const operatorKeys = {\n                    contains: { operator: 'ilike', wildcard: '%' },\n                    equals: { operator: '=', wildcard: '' },\n                    exists: { operator: val === true ? 'is not null' : 'is null' },\n                    like: { operator: 'like', wildcard: '%' },\n                    not_equals: { operator: '<>', wildcard: '' },\n                  }\n                  let formattedValue = `'${operatorKeys[operator].wildcard}${val}${operatorKeys[operator].wildcard}'`\n\n                  if (operator === 'exists') {\n                    formattedValue = ''\n                  }\n\n                  constraints.push(\n                    sql.raw(\n                      `${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`,\n                    ),\n                  )\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const sanitizedQueryValue = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (sanitizedQueryValue === null) {\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizedQueryValue\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                  break\n                }\n\n                if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n\n                  break\n                }\n\n                constraints.push(\n                  operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                )\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","operatorKeys","contains","wildcard","exists","not_equals","formattedValue","isNotNull","QueryError","path","and","map","word","ilike","sanitizedQueryValue","sanitizeQueryValue","queryOperator","queryValue","or","isNull","ne","notInArray"],"mappings":"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"}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (\n                  ['json', 'richText'].includes(field.type) &&\n                  Array.isArray(pathSegments) &&\n                  pathSegments.length > 1\n                ) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                    break\n                  }\n\n                  const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                  const operatorKeys = {\n                    contains: { operator: 'ilike', wildcard: '%' },\n                    equals: { operator: '=', wildcard: '' },\n                    exists: { operator: val === true ? 'is not null' : 'is null' },\n                    like: { operator: 'like', wildcard: '%' },\n                    not_equals: { operator: '<>', wildcard: '' },\n                  }\n                  let formattedValue = `'${operatorKeys[operator].wildcard}${val}${operatorKeys[operator].wildcard}'`\n\n                  if (operator === 'exists') {\n                    formattedValue = ''\n                  }\n\n                  constraints.push(\n                    sql.raw(\n                      `${table[columnName].name}${jsonQuery} ${operatorKeys[operator].operator} ${formattedValue}`,\n                    ),\n                  )\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const sanitizedQueryValue = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (sanitizedQueryValue === null) {\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizedQueryValue\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                  break\n                }\n\n                if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n\n                  break\n                }\n\n                if (operator === 'equals' && queryValue === null) {\n                  constraints.push(isNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                if (operator === 'not_equals' && queryValue === null) {\n                  constraints.push(isNotNull(rawColumn || table[columnName]))\n                  break\n                }\n\n                constraints.push(\n                  operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                )\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","operatorKeys","contains","wildcard","exists","not_equals","formattedValue","isNotNull","QueryError","path","and","map","word","ilike","sanitizedQueryValue","sanitizeQueryValue","queryOperator","queryValue","or","isNull","ne","notInArray"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"validateExistingBlockIsIdentical.d.ts","sourceRoot":"","sources":["../../src/schema/validateExistingBlockIsIdentical.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAS,MAAM,eAAe,CAAA;AAKjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAE5C,KAAK,IAAI,GAAG;IACV,KAAK,EAAE,KAAK,CAAA;IACZ,SAAS,EAAE,OAAO,CAAA;IAClB,aAAa,EAAE,MAAM,CAAA;IACrB,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAsCD,eAAO,MAAM,gCAAgC,gDAK1C,IAAI,KAAG,IA0BT,CAAA"}
1
+ {"version":3,"file":"validateExistingBlockIsIdentical.d.ts","sourceRoot":"","sources":["../../src/schema/validateExistingBlockIsIdentical.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAS,MAAM,eAAe,CAAA;AAKjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAE5C,KAAK,IAAI,GAAG;IACV,KAAK,EAAE,KAAK,CAAA;IACZ,SAAS,EAAE,OAAO,CAAA;IAClB,aAAa,EAAE,MAAM,CAAA;IACrB,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAyCD,eAAO,MAAM,gCAAgC,gDAK1C,IAAI,KAAG,IAwBT,CAAA"}
@@ -13,7 +13,12 @@ const _types = require("payload/types");
13
13
  const getFlattenedFieldNames = (fields, prefix = '')=>{
14
14
  return fields.reduce((fieldsToUse, field)=>{
15
15
  let fieldPrefix = prefix;
16
- if (field.type === 'blocks') {
16
+ if ([
17
+ 'array',
18
+ 'blocks',
19
+ 'relationship',
20
+ 'upload'
21
+ ].includes(field.type) || 'hasMany' in field && field.hasMany === true) {
17
22
  return fieldsToUse;
18
23
  }
19
24
  if ((0, _types.fieldHasSubFields)(field)) {
@@ -50,28 +55,26 @@ const getFlattenedFieldNames = (fields, prefix = '')=>{
50
55
  }, []);
51
56
  };
52
57
  const validateExistingBlockIsIdentical = ({ block, localized, rootTableName, table })=>{
53
- if (table) {
54
- const fieldNames = getFlattenedFieldNames(block.fields);
55
- const missingField = // ensure every field from the config is in the matching table
56
- fieldNames.find((name)=>Object.keys(table).indexOf(name) === -1) || // ensure every table column is matched for every field from the config
57
- Object.keys(table).find((fieldName)=>{
58
- if (![
59
- '_locale',
60
- '_order',
61
- '_parentID',
62
- '_path',
63
- '_uuid'
64
- ].includes(fieldName)) {
65
- return fieldNames.indexOf(fieldName) === -1;
66
- }
67
- });
68
- if (missingField) {
69
- throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One block includes the field ${missingField}, while the other block does not.`);
70
- }
71
- if (Boolean(localized) !== Boolean(table._locale)) {
72
- throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One is localized, but another is not. Block schemas of the same name must match exactly.`);
58
+ const fieldNames = getFlattenedFieldNames(block.fields);
59
+ const missingField = // ensure every field from the config is in the matching table
60
+ fieldNames.find((name)=>Object.keys(table).indexOf(name) === -1) || // ensure every table column is matched for every field from the config
61
+ Object.keys(table).find((fieldName)=>{
62
+ if (![
63
+ '_locale',
64
+ '_order',
65
+ '_parentID',
66
+ '_path',
67
+ '_uuid'
68
+ ].includes(fieldName)) {
69
+ return fieldNames.indexOf(fieldName) === -1;
73
70
  }
71
+ });
72
+ if (missingField) {
73
+ throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One block includes the field ${missingField}, while the other block does not.`);
74
+ }
75
+ if (Boolean(localized) !== Boolean(table._locale)) {
76
+ throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One is localized, but another is not. Block schemas of the same name must match exactly.`);
74
77
  }
75
78
  };
76
79
 
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvdmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCbG9jaywgRmllbGQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgeyBJbnZhbGlkQ29uZmlndXJhdGlvbiB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgZmllbGRBZmZlY3RzRGF0YSwgZmllbGRIYXNTdWJGaWVsZHMsIHRhYkhhc05hbWUgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgdHlwZSB7IEdlbmVyaWNUYWJsZSB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGJsb2NrOiBCbG9ja1xuICBsb2NhbGl6ZWQ6IGJvb2xlYW5cbiAgcm9vdFRhYmxlTmFtZTogc3RyaW5nXG4gIHRhYmxlOiBHZW5lcmljVGFibGVcbn1cblxuY29uc3QgZ2V0RmxhdHRlbmVkRmllbGROYW1lcyA9IChmaWVsZHM6IEZpZWxkW10sIHByZWZpeDogc3RyaW5nID0gJycpOiBzdHJpbmdbXSA9PiB7XG4gIHJldHVybiBmaWVsZHMucmVkdWNlKChmaWVsZHNUb1VzZSwgZmllbGQpID0+IHtcbiAgICBsZXQgZmllbGRQcmVmaXggPSBwcmVmaXhcblxuICAgIGlmIChmaWVsZC50eXBlID09PSAnYmxvY2tzJykge1xuICAgICAgcmV0dXJuIGZpZWxkc1RvVXNlXG4gICAgfVxuXG4gICAgaWYgKGZpZWxkSGFzU3ViRmllbGRzKGZpZWxkKSkge1xuICAgICAgZmllbGRQcmVmaXggPSAnbmFtZScgaW4gZmllbGQgPyBgJHtwcmVmaXh9JHtmaWVsZC5uYW1lfS5gIDogcHJlZml4XG4gICAgICByZXR1cm4gWy4uLmZpZWxkc1RvVXNlLCAuLi5nZXRGbGF0dGVuZWRGaWVsZE5hbWVzKGZpZWxkLmZpZWxkcywgZmllbGRQcmVmaXgpXVxuICAgIH1cblxuICAgIGlmIChmaWVsZC50eXBlID09PSAndGFicycpIHtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIC4uLmZpZWxkc1RvVXNlLFxuICAgICAgICAuLi5maWVsZC50YWJzLnJlZHVjZSgodGFiRmllbGRzLCB0YWIpID0+IHtcbiAgICAgICAgICBmaWVsZFByZWZpeCA9ICduYW1lJyBpbiB0YWIgPyBgJHtwcmVmaXh9LiR7dGFiLm5hbWV9YCA6IHByZWZpeFxuICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICAuLi50YWJGaWVsZHMsXG4gICAgICAgICAgICAuLi4odGFiSGFzTmFtZSh0YWIpXG4gICAgICAgICAgICAgID8gW3sgLi4udGFiLCB0eXBlOiAndGFiJyB9XVxuICAgICAgICAgICAgICA6IGdldEZsYXR0ZW5lZEZpZWxkTmFtZXModGFiLmZpZWxkcywgZmllbGRQcmVmaXgpKSxcbiAgICAgICAgICBdXG4gICAgICAgIH0sIFtdKSxcbiAgICAgIF1cbiAgICB9XG5cbiAgICBpZiAoZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHtcbiAgICAgIHJldHVybiBbLi4uZmllbGRzVG9Vc2UsIGAke2ZpZWxkUHJlZml4Py5yZXBsYWNlKCcuJywgJ18nKSB8fCAnJ30ke2ZpZWxkLm5hbWV9YF1cbiAgICB9XG5cbiAgICByZXR1cm4gZmllbGRzVG9Vc2VcbiAgfSwgW10pXG59XG5cbmV4cG9ydCBjb25zdCB2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCA9ICh7XG4gIGJsb2NrLFxuICBsb2NhbGl6ZWQsXG4gIHJvb3RUYWJsZU5hbWUsXG4gIHRhYmxlLFxufTogQXJncyk6IHZvaWQgPT4ge1xuICBpZiAodGFibGUpIHtcbiAgICBjb25zdCBmaWVsZE5hbWVzID0gZ2V0RmxhdHRlbmVkRmllbGROYW1lcyhibG9jay5maWVsZHMpXG5cbiAgICBjb25zdCBtaXNzaW5nRmllbGQgPVxuICAgICAgLy8gZW5zdXJlIGV2ZXJ5IGZpZWxkIGZyb20gdGhlIGNvbmZpZyBpcyBpbiB0aGUgbWF0Y2hpbmcgdGFibGVcbiAgICAgIGZpZWxkTmFtZXMuZmluZCgobmFtZSkgPT4gT2JqZWN0LmtleXModGFibGUpLmluZGV4T2YobmFtZSkgPT09IC0xKSB8fFxuICAgICAgLy8gZW5zdXJlIGV2ZXJ5IHRhYmxlIGNvbHVtbiBpcyBtYXRjaGVkIGZvciBldmVyeSBmaWVsZCBmcm9tIHRoZSBjb25maWdcbiAgICAgIE9iamVjdC5rZXlzKHRhYmxlKS5maW5kKChmaWVsZE5hbWUpID0+IHtcbiAgICAgICAgaWYgKCFbJ19sb2NhbGUnLCAnX29yZGVyJywgJ19wYXJlbnRJRCcsICdfcGF0aCcsICdfdXVpZCddLmluY2x1ZGVzKGZpZWxkTmFtZSkpIHtcbiAgICAgICAgICByZXR1cm4gZmllbGROYW1lcy5pbmRleE9mKGZpZWxkTmFtZSkgPT09IC0xXG4gICAgICAgIH1cbiAgICAgIH0pXG5cbiAgICBpZiAobWlzc2luZ0ZpZWxkKSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZENvbmZpZ3VyYXRpb24oXG4gICAgICAgIGBUaGUgdGFibGUgJHtyb290VGFibGVOYW1lfSBoYXMgbXVsdGlwbGUgYmxvY2tzIHdpdGggc2x1ZyAke2Jsb2NrLnNsdWd9LCBidXQgdGhlIHNjaGVtYXMgZG8gbm90IG1hdGNoLiBPbmUgYmxvY2sgaW5jbHVkZXMgdGhlIGZpZWxkICR7bWlzc2luZ0ZpZWxkfSwgd2hpbGUgdGhlIG90aGVyIGJsb2NrIGRvZXMgbm90LmAsXG4gICAgICApXG4gICAgfVxuXG4gICAgaWYgKEJvb2xlYW4obG9jYWxpemVkKSAhPT0gQm9vbGVhbih0YWJsZS5fbG9jYWxlKSkge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICBgVGhlIHRhYmxlICR7cm9vdFRhYmxlTmFtZX0gaGFzIG11bHRpcGxlIGJsb2NrcyB3aXRoIHNsdWcgJHtibG9jay5zbHVnfSwgYnV0IHRoZSBzY2hlbWFzIGRvIG5vdCBtYXRjaC4gT25lIGlzIGxvY2FsaXplZCwgYnV0IGFub3RoZXIgaXMgbm90LiBCbG9jayBzY2hlbWFzIG9mIHRoZSBzYW1lIG5hbWUgbXVzdCBtYXRjaCBleGFjdGx5LmAsXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsidmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwiLCJnZXRGbGF0dGVuZWRGaWVsZE5hbWVzIiwiZmllbGRzIiwicHJlZml4IiwicmVkdWNlIiwiZmllbGRzVG9Vc2UiLCJmaWVsZCIsImZpZWxkUHJlZml4IiwidHlwZSIsImZpZWxkSGFzU3ViRmllbGRzIiwibmFtZSIsInRhYnMiLCJ0YWJGaWVsZHMiLCJ0YWIiLCJ0YWJIYXNOYW1lIiwiZmllbGRBZmZlY3RzRGF0YSIsInJlcGxhY2UiLCJibG9jayIsImxvY2FsaXplZCIsInJvb3RUYWJsZU5hbWUiLCJ0YWJsZSIsImZpZWxkTmFtZXMiLCJtaXNzaW5nRmllbGQiLCJmaW5kIiwiT2JqZWN0Iiwia2V5cyIsImluZGV4T2YiLCJmaWVsZE5hbWUiLCJpbmNsdWRlcyIsIkludmFsaWRDb25maWd1cmF0aW9uIiwic2x1ZyIsIkJvb2xlYW4iLCJfbG9jYWxlIl0sIm1hcHBpbmdzIjoiOzs7OytCQWtEYUE7OztlQUFBQTs7O3dCQWhEd0I7dUJBQzJCO0FBV2hFLE1BQU1DLHlCQUF5QixDQUFDQyxRQUFpQkMsU0FBaUIsRUFBRTtJQUNsRSxPQUFPRCxPQUFPRSxNQUFNLENBQUMsQ0FBQ0MsYUFBYUM7UUFDakMsSUFBSUMsY0FBY0o7UUFFbEIsSUFBSUcsTUFBTUUsSUFBSSxLQUFLLFVBQVU7WUFDM0IsT0FBT0g7UUFDVDtRQUVBLElBQUlJLElBQUFBLHdCQUFpQixFQUFDSCxRQUFRO1lBQzVCQyxjQUFjLFVBQVVELFFBQVEsQ0FBQyxFQUFFSCxPQUFPLEVBQUVHLE1BQU1JLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBR1A7WUFDNUQsT0FBTzttQkFBSUU7bUJBQWdCSix1QkFBdUJLLE1BQU1KLE1BQU0sRUFBRUs7YUFBYTtRQUMvRTtRQUVBLElBQUlELE1BQU1FLElBQUksS0FBSyxRQUFRO1lBQ3pCLE9BQU87bUJBQ0ZIO21CQUNBQyxNQUFNSyxJQUFJLENBQUNQLE1BQU0sQ0FBQyxDQUFDUSxXQUFXQztvQkFDL0JOLGNBQWMsVUFBVU0sTUFBTSxDQUFDLEVBQUVWLE9BQU8sQ0FBQyxFQUFFVSxJQUFJSCxJQUFJLENBQUMsQ0FBQyxHQUFHUDtvQkFDeEQsT0FBTzsyQkFDRlM7MkJBQ0NFLElBQUFBLGlCQUFVLEVBQUNELE9BQ1g7NEJBQUM7Z0NBQUUsR0FBR0EsR0FBRztnQ0FBRUwsTUFBTTs0QkFBTTt5QkFBRSxHQUN6QlAsdUJBQXVCWSxJQUFJWCxNQUFNLEVBQUVLO3FCQUN4QztnQkFDSCxHQUFHLEVBQUU7YUFDTjtRQUNIO1FBRUEsSUFBSVEsSUFBQUEsdUJBQWdCLEVBQUNULFFBQVE7WUFDM0IsT0FBTzttQkFBSUQ7Z0JBQWEsQ0FBQyxFQUFFRSxhQUFhUyxRQUFRLEtBQUssUUFBUSxHQUFHLEVBQUVWLE1BQU1JLElBQUksQ0FBQyxDQUFDO2FBQUM7UUFDakY7UUFFQSxPQUFPTDtJQUNULEdBQUcsRUFBRTtBQUNQO0FBRU8sTUFBTUwsbUNBQW1DLENBQUMsRUFDL0NpQixLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsYUFBYSxFQUNiQyxLQUFLLEVBQ0E7SUFDTCxJQUFJQSxPQUFPO1FBQ1QsTUFBTUMsYUFBYXBCLHVCQUF1QmdCLE1BQU1mLE1BQU07UUFFdEQsTUFBTW9CLGVBQ0osOERBQThEO1FBQzlERCxXQUFXRSxJQUFJLENBQUMsQ0FBQ2IsT0FBU2MsT0FBT0MsSUFBSSxDQUFDTCxPQUFPTSxPQUFPLENBQUNoQixVQUFVLENBQUMsTUFDaEUsdUVBQXVFO1FBQ3ZFYyxPQUFPQyxJQUFJLENBQUNMLE9BQU9HLElBQUksQ0FBQyxDQUFDSTtZQUN2QixJQUFJLENBQUM7Z0JBQUM7Z0JBQVc7Z0JBQVU7Z0JBQWE7Z0JBQVM7YUFBUSxDQUFDQyxRQUFRLENBQUNELFlBQVk7Z0JBQzdFLE9BQU9OLFdBQVdLLE9BQU8sQ0FBQ0MsZUFBZSxDQUFDO1lBQzVDO1FBQ0Y7UUFFRixJQUFJTCxjQUFjO1lBQ2hCLE1BQU0sSUFBSU8sNEJBQW9CLENBQzVCLENBQUMsVUFBVSxFQUFFVixjQUFjLCtCQUErQixFQUFFRixNQUFNYSxJQUFJLENBQUMsNkRBQTZELEVBQUVSLGFBQWEsaUNBQWlDLENBQUM7UUFFekw7UUFFQSxJQUFJUyxRQUFRYixlQUFlYSxRQUFRWCxNQUFNWSxPQUFPLEdBQUc7WUFDakQsTUFBTSxJQUFJSCw0QkFBb0IsQ0FDNUIsQ0FBQyxVQUFVLEVBQUVWLGNBQWMsK0JBQStCLEVBQUVGLE1BQU1hLElBQUksQ0FBQyx3SEFBd0gsQ0FBQztRQUVwTTtJQUNGO0FBQ0YifQ==
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvdmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCbG9jaywgRmllbGQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgeyBJbnZhbGlkQ29uZmlndXJhdGlvbiB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgZmllbGRBZmZlY3RzRGF0YSwgZmllbGRIYXNTdWJGaWVsZHMsIHRhYkhhc05hbWUgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgdHlwZSB7IEdlbmVyaWNUYWJsZSB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGJsb2NrOiBCbG9ja1xuICBsb2NhbGl6ZWQ6IGJvb2xlYW5cbiAgcm9vdFRhYmxlTmFtZTogc3RyaW5nXG4gIHRhYmxlOiBHZW5lcmljVGFibGVcbn1cblxuY29uc3QgZ2V0RmxhdHRlbmVkRmllbGROYW1lcyA9IChmaWVsZHM6IEZpZWxkW10sIHByZWZpeDogc3RyaW5nID0gJycpOiBzdHJpbmdbXSA9PiB7XG4gIHJldHVybiBmaWVsZHMucmVkdWNlKChmaWVsZHNUb1VzZSwgZmllbGQpID0+IHtcbiAgICBsZXQgZmllbGRQcmVmaXggPSBwcmVmaXhcblxuICAgIGlmIChcbiAgICAgIFsnYXJyYXknLCAnYmxvY2tzJywgJ3JlbGF0aW9uc2hpcCcsICd1cGxvYWQnXS5pbmNsdWRlcyhmaWVsZC50eXBlKSB8fFxuICAgICAgKCdoYXNNYW55JyBpbiBmaWVsZCAmJiBmaWVsZC5oYXNNYW55ID09PSB0cnVlKVxuICAgICkge1xuICAgICAgcmV0dXJuIGZpZWxkc1RvVXNlXG4gICAgfVxuXG4gICAgaWYgKGZpZWxkSGFzU3ViRmllbGRzKGZpZWxkKSkge1xuICAgICAgZmllbGRQcmVmaXggPSAnbmFtZScgaW4gZmllbGQgPyBgJHtwcmVmaXh9JHtmaWVsZC5uYW1lfS5gIDogcHJlZml4XG4gICAgICByZXR1cm4gWy4uLmZpZWxkc1RvVXNlLCAuLi5nZXRGbGF0dGVuZWRGaWVsZE5hbWVzKGZpZWxkLmZpZWxkcywgZmllbGRQcmVmaXgpXVxuICAgIH1cblxuICAgIGlmIChmaWVsZC50eXBlID09PSAndGFicycpIHtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIC4uLmZpZWxkc1RvVXNlLFxuICAgICAgICAuLi5maWVsZC50YWJzLnJlZHVjZSgodGFiRmllbGRzLCB0YWIpID0+IHtcbiAgICAgICAgICBmaWVsZFByZWZpeCA9ICduYW1lJyBpbiB0YWIgPyBgJHtwcmVmaXh9LiR7dGFiLm5hbWV9YCA6IHByZWZpeFxuICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICAuLi50YWJGaWVsZHMsXG4gICAgICAgICAgICAuLi4odGFiSGFzTmFtZSh0YWIpXG4gICAgICAgICAgICAgID8gW3sgLi4udGFiLCB0eXBlOiAndGFiJyB9XVxuICAgICAgICAgICAgICA6IGdldEZsYXR0ZW5lZEZpZWxkTmFtZXModGFiLmZpZWxkcywgZmllbGRQcmVmaXgpKSxcbiAgICAgICAgICBdXG4gICAgICAgIH0sIFtdKSxcbiAgICAgIF1cbiAgICB9XG5cbiAgICBpZiAoZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHtcbiAgICAgIHJldHVybiBbLi4uZmllbGRzVG9Vc2UsIGAke2ZpZWxkUHJlZml4Py5yZXBsYWNlKCcuJywgJ18nKSB8fCAnJ30ke2ZpZWxkLm5hbWV9YF1cbiAgICB9XG5cbiAgICByZXR1cm4gZmllbGRzVG9Vc2VcbiAgfSwgW10pXG59XG5cbmV4cG9ydCBjb25zdCB2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCA9ICh7XG4gIGJsb2NrLFxuICBsb2NhbGl6ZWQsXG4gIHJvb3RUYWJsZU5hbWUsXG4gIHRhYmxlLFxufTogQXJncyk6IHZvaWQgPT4ge1xuICBjb25zdCBmaWVsZE5hbWVzID0gZ2V0RmxhdHRlbmVkRmllbGROYW1lcyhibG9jay5maWVsZHMpXG5cbiAgY29uc3QgbWlzc2luZ0ZpZWxkID1cbiAgICAvLyBlbnN1cmUgZXZlcnkgZmllbGQgZnJvbSB0aGUgY29uZmlnIGlzIGluIHRoZSBtYXRjaGluZyB0YWJsZVxuICAgIGZpZWxkTmFtZXMuZmluZCgobmFtZSkgPT4gT2JqZWN0LmtleXModGFibGUpLmluZGV4T2YobmFtZSkgPT09IC0xKSB8fFxuICAgIC8vIGVuc3VyZSBldmVyeSB0YWJsZSBjb2x1bW4gaXMgbWF0Y2hlZCBmb3IgZXZlcnkgZmllbGQgZnJvbSB0aGUgY29uZmlnXG4gICAgT2JqZWN0LmtleXModGFibGUpLmZpbmQoKGZpZWxkTmFtZSkgPT4ge1xuICAgICAgaWYgKCFbJ19sb2NhbGUnLCAnX29yZGVyJywgJ19wYXJlbnRJRCcsICdfcGF0aCcsICdfdXVpZCddLmluY2x1ZGVzKGZpZWxkTmFtZSkpIHtcbiAgICAgICAgcmV0dXJuIGZpZWxkTmFtZXMuaW5kZXhPZihmaWVsZE5hbWUpID09PSAtMVxuICAgICAgfVxuICAgIH0pXG5cbiAgaWYgKG1pc3NpbmdGaWVsZCkge1xuICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlndXJhdGlvbihcbiAgICAgIGBUaGUgdGFibGUgJHtyb290VGFibGVOYW1lfSBoYXMgbXVsdGlwbGUgYmxvY2tzIHdpdGggc2x1ZyAke2Jsb2NrLnNsdWd9LCBidXQgdGhlIHNjaGVtYXMgZG8gbm90IG1hdGNoLiBPbmUgYmxvY2sgaW5jbHVkZXMgdGhlIGZpZWxkICR7bWlzc2luZ0ZpZWxkfSwgd2hpbGUgdGhlIG90aGVyIGJsb2NrIGRvZXMgbm90LmAsXG4gICAgKVxuICB9XG5cbiAgaWYgKEJvb2xlYW4obG9jYWxpemVkKSAhPT0gQm9vbGVhbih0YWJsZS5fbG9jYWxlKSkge1xuICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlndXJhdGlvbihcbiAgICAgIGBUaGUgdGFibGUgJHtyb290VGFibGVOYW1lfSBoYXMgbXVsdGlwbGUgYmxvY2tzIHdpdGggc2x1ZyAke2Jsb2NrLnNsdWd9LCBidXQgdGhlIHNjaGVtYXMgZG8gbm90IG1hdGNoLiBPbmUgaXMgbG9jYWxpemVkLCBidXQgYW5vdGhlciBpcyBub3QuIEJsb2NrIHNjaGVtYXMgb2YgdGhlIHNhbWUgbmFtZSBtdXN0IG1hdGNoIGV4YWN0bHkuYCxcbiAgICApXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJ2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCIsImdldEZsYXR0ZW5lZEZpZWxkTmFtZXMiLCJmaWVsZHMiLCJwcmVmaXgiLCJyZWR1Y2UiLCJmaWVsZHNUb1VzZSIsImZpZWxkIiwiZmllbGRQcmVmaXgiLCJpbmNsdWRlcyIsInR5cGUiLCJoYXNNYW55IiwiZmllbGRIYXNTdWJGaWVsZHMiLCJuYW1lIiwidGFicyIsInRhYkZpZWxkcyIsInRhYiIsInRhYkhhc05hbWUiLCJmaWVsZEFmZmVjdHNEYXRhIiwicmVwbGFjZSIsImJsb2NrIiwibG9jYWxpemVkIiwicm9vdFRhYmxlTmFtZSIsInRhYmxlIiwiZmllbGROYW1lcyIsIm1pc3NpbmdGaWVsZCIsImZpbmQiLCJPYmplY3QiLCJrZXlzIiwiaW5kZXhPZiIsImZpZWxkTmFtZSIsIkludmFsaWRDb25maWd1cmF0aW9uIiwic2x1ZyIsIkJvb2xlYW4iLCJfbG9jYWxlIl0sIm1hcHBpbmdzIjoiOzs7OytCQXFEYUE7OztlQUFBQTs7O3dCQW5Ed0I7dUJBQzJCO0FBV2hFLE1BQU1DLHlCQUF5QixDQUFDQyxRQUFpQkMsU0FBaUIsRUFBRTtJQUNsRSxPQUFPRCxPQUFPRSxNQUFNLENBQUMsQ0FBQ0MsYUFBYUM7UUFDakMsSUFBSUMsY0FBY0o7UUFFbEIsSUFDRTtZQUFDO1lBQVM7WUFBVTtZQUFnQjtTQUFTLENBQUNLLFFBQVEsQ0FBQ0YsTUFBTUcsSUFBSSxLQUNoRSxhQUFhSCxTQUFTQSxNQUFNSSxPQUFPLEtBQUssTUFDekM7WUFDQSxPQUFPTDtRQUNUO1FBRUEsSUFBSU0sSUFBQUEsd0JBQWlCLEVBQUNMLFFBQVE7WUFDNUJDLGNBQWMsVUFBVUQsUUFBUSxDQUFDLEVBQUVILE9BQU8sRUFBRUcsTUFBTU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHVDtZQUM1RCxPQUFPO21CQUFJRTttQkFBZ0JKLHVCQUF1QkssTUFBTUosTUFBTSxFQUFFSzthQUFhO1FBQy9FO1FBRUEsSUFBSUQsTUFBTUcsSUFBSSxLQUFLLFFBQVE7WUFDekIsT0FBTzttQkFDRko7bUJBQ0FDLE1BQU1PLElBQUksQ0FBQ1QsTUFBTSxDQUFDLENBQUNVLFdBQVdDO29CQUMvQlIsY0FBYyxVQUFVUSxNQUFNLENBQUMsRUFBRVosT0FBTyxDQUFDLEVBQUVZLElBQUlILElBQUksQ0FBQyxDQUFDLEdBQUdUO29CQUN4RCxPQUFPOzJCQUNGVzsyQkFDQ0UsSUFBQUEsaUJBQVUsRUFBQ0QsT0FDWDs0QkFBQztnQ0FBRSxHQUFHQSxHQUFHO2dDQUFFTixNQUFNOzRCQUFNO3lCQUFFLEdBQ3pCUix1QkFBdUJjLElBQUliLE1BQU0sRUFBRUs7cUJBQ3hDO2dCQUNILEdBQUcsRUFBRTthQUNOO1FBQ0g7UUFFQSxJQUFJVSxJQUFBQSx1QkFBZ0IsRUFBQ1gsUUFBUTtZQUMzQixPQUFPO21CQUFJRDtnQkFBYSxDQUFDLEVBQUVFLGFBQWFXLFFBQVEsS0FBSyxRQUFRLEdBQUcsRUFBRVosTUFBTU0sSUFBSSxDQUFDLENBQUM7YUFBQztRQUNqRjtRQUVBLE9BQU9QO0lBQ1QsR0FBRyxFQUFFO0FBQ1A7QUFFTyxNQUFNTCxtQ0FBbUMsQ0FBQyxFQUMvQ21CLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxhQUFhLEVBQ2JDLEtBQUssRUFDQTtJQUNMLE1BQU1DLGFBQWF0Qix1QkFBdUJrQixNQUFNakIsTUFBTTtJQUV0RCxNQUFNc0IsZUFDSiw4REFBOEQ7SUFDOURELFdBQVdFLElBQUksQ0FBQyxDQUFDYixPQUFTYyxPQUFPQyxJQUFJLENBQUNMLE9BQU9NLE9BQU8sQ0FBQ2hCLFVBQVUsQ0FBQyxNQUNoRSx1RUFBdUU7SUFDdkVjLE9BQU9DLElBQUksQ0FBQ0wsT0FBT0csSUFBSSxDQUFDLENBQUNJO1FBQ3ZCLElBQUksQ0FBQztZQUFDO1lBQVc7WUFBVTtZQUFhO1lBQVM7U0FBUSxDQUFDckIsUUFBUSxDQUFDcUIsWUFBWTtZQUM3RSxPQUFPTixXQUFXSyxPQUFPLENBQUNDLGVBQWUsQ0FBQztRQUM1QztJQUNGO0lBRUYsSUFBSUwsY0FBYztRQUNoQixNQUFNLElBQUlNLDRCQUFvQixDQUM1QixDQUFDLFVBQVUsRUFBRVQsY0FBYywrQkFBK0IsRUFBRUYsTUFBTVksSUFBSSxDQUFDLDZEQUE2RCxFQUFFUCxhQUFhLGlDQUFpQyxDQUFDO0lBRXpMO0lBRUEsSUFBSVEsUUFBUVosZUFBZVksUUFBUVYsTUFBTVcsT0FBTyxHQUFHO1FBQ2pELE1BQU0sSUFBSUgsNEJBQW9CLENBQzVCLENBQUMsVUFBVSxFQUFFVCxjQUFjLCtCQUErQixFQUFFRixNQUFNWSxJQUFJLENBQUMsd0hBQXdILENBQUM7SUFFcE07QUFDRiJ9
@@ -26,10 +26,6 @@ type TraverseFieldsArgs = {
26
26
  * An array of Payload fields to traverse
27
27
  */
28
28
  fields: (Field | TabAsField)[];
29
- /**
30
- * All hasMany text fields, as returned by Drizzle, keyed on an object by field path
31
- */
32
- texts: Record<string, Record<string, unknown>[]>;
33
29
  /**
34
30
  * All hasMany number fields, as returned by Drizzle, keyed on an object by field path
35
31
  */
@@ -46,7 +42,11 @@ type TraverseFieldsArgs = {
46
42
  * Data structure representing the nearest table from db
47
43
  */
48
44
  table: Record<string, unknown>;
45
+ /**
46
+ * All hasMany text fields, as returned by Drizzle, keyed on an object by field path
47
+ */
48
+ texts: Record<string, Record<string, unknown>[]>;
49
49
  };
50
- export declare const traverseFields: <T extends Record<string, unknown>>({ blocks, config, dataRef, deletions, fieldPrefix, fields, texts, numbers, path, relationships, table, }: TraverseFieldsArgs) => T;
50
+ export declare const traverseFields: <T extends Record<string, unknown>>({ blocks, config, dataRef, deletions, fieldPrefix, fields, numbers, path, relationships, table, texts, }: TraverseFieldsArgs) => T;
51
51
  export {};
52
52
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/transform/read/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAItD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAA;AAMhE,KAAK,kBAAkB,GAAG;IACxB;;OAEG;IACH,MAAM,EAAE,SAAS,CAAA;IACjB;;OAEG;IACH,MAAM,EAAE,eAAe,CAAA;IACvB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC;;OAEG;IACH,SAAS,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IACzB;;OAEG;IACH,WAAW,EAAE,MAAM,CAAA;IACnB;;OAEG;IACH,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;IAChD;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;IAClD;;OAEG;IACH,IAAI,EAAE,MAAM,CAAA;IACZ;;OAEG;IACH,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;IACxD;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC/B,CAAA;AAID,eAAO,MAAM,cAAc,gJAYxB,kBAAkB,MAkcpB,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/transform/read/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAItD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAA;AAMhE,KAAK,kBAAkB,GAAG;IACxB;;OAEG;IACH,MAAM,EAAE,SAAS,CAAA;IACjB;;OAEG;IACH,MAAM,EAAE,eAAe,CAAA;IACvB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC;;OAEG;IACH,SAAS,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAA;IACzB;;OAEG;IACH,WAAW,EAAE,MAAM,CAAA;IACnB;;OAEG;IACH,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;IAClD;;OAEG;IACH,IAAI,EAAE,MAAM,CAAA;IACZ;;OAEG;IACH,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;IACxD;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC9B;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;CACjD,CAAA;AAID,eAAO,MAAM,cAAc,gJAYxB,kBAAkB,MAsdpB,CAAA"}
@@ -10,9 +10,9 @@ Object.defineProperty(exports, "traverseFields", {
10
10
  });
11
11
  const _types = require("payload/types");
12
12
  const _hasManyNumber = require("./hasManyNumber");
13
- const _relationship = require("./relationship");
14
13
  const _hasManyText = require("./hasManyText");
15
- const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, fields, texts, numbers, path, relationships, table })=>{
14
+ const _relationship = require("./relationship");
15
+ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, fields, numbers, path, relationships, table, texts })=>{
16
16
  const sanitizedPath = path ? `${path}.` : path;
17
17
  const formatted = fields.reduce((result, field)=>{
18
18
  if (field.type === 'tabs') {
@@ -26,11 +26,11 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
26
26
  ...tab,
27
27
  type: 'tab'
28
28
  })),
29
- texts,
30
29
  numbers,
31
30
  path,
32
31
  relationships,
33
- table
32
+ table,
33
+ texts
34
34
  });
35
35
  }
36
36
  if (field.type === 'collapsible' || field.type === 'row' || field.type === 'tab' && !('name' in field)) {
@@ -41,16 +41,19 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
41
41
  deletions,
42
42
  fieldPrefix,
43
43
  fields: field.fields,
44
- texts,
45
44
  numbers,
46
45
  path,
47
46
  relationships,
48
- table
47
+ table,
48
+ texts
49
49
  });
50
50
  }
51
51
  if ((0, _types.fieldAffectsData)(field)) {
52
52
  const fieldName = `${fieldPrefix || ''}${field.name}`;
53
53
  const fieldData = table[fieldName];
54
+ if (fieldPrefix) {
55
+ deletions.push(()=>delete table[fieldName]);
56
+ }
54
57
  if (field.type === 'array') {
55
58
  if (Array.isArray(fieldData)) {
56
59
  if (field.localized) {
@@ -71,12 +74,15 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
71
74
  deletions,
72
75
  fieldPrefix: '',
73
76
  fields: field.fields,
74
- texts,
75
77
  numbers,
76
78
  path: `${sanitizedPath}${field.name}.${row._order - 1}`,
77
79
  relationships,
78
- table: row
80
+ table: row,
81
+ texts
79
82
  });
83
+ if ('_order' in rowResult) {
84
+ delete rowResult._order;
85
+ }
80
86
  arrayResult[locale].push(rowResult);
81
87
  }
82
88
  return arrayResult;
@@ -87,6 +93,9 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
87
93
  row.id = row._uuid;
88
94
  delete row._uuid;
89
95
  }
96
+ if ('_order' in row) {
97
+ delete row._order;
98
+ }
90
99
  return traverseFields({
91
100
  blocks,
92
101
  config,
@@ -94,11 +103,11 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
94
103
  deletions,
95
104
  fieldPrefix: '',
96
105
  fields: field.fields,
97
- texts,
98
106
  numbers,
99
107
  path: `${sanitizedPath}${field.name}.${i}`,
100
108
  relationships,
101
- table: row
109
+ table: row,
110
+ texts
102
111
  });
103
112
  });
104
113
  }
@@ -132,11 +141,11 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
132
141
  deletions,
133
142
  fieldPrefix: '',
134
143
  fields: block.fields,
135
- texts,
136
144
  numbers,
137
145
  path: `${blockFieldPath}.${row._order - 1}`,
138
146
  relationships,
139
- table: row
147
+ table: row,
148
+ texts
140
149
  });
141
150
  delete blockResult._order;
142
151
  return blockResult;
@@ -160,11 +169,11 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
160
169
  deletions,
161
170
  fieldPrefix: '',
162
171
  fields: block.fields,
163
- texts,
164
172
  numbers,
165
173
  path: `${blockFieldPath}.${i}`,
166
174
  relationships,
167
- table: row
175
+ table: row,
176
+ texts
168
177
  });
169
178
  }
170
179
  return {};
@@ -229,15 +238,15 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
229
238
  (0, _hasManyText.transformHasManyText)({
230
239
  field,
231
240
  locale,
232
- textRows: texts,
233
- ref: result
241
+ ref: result,
242
+ textRows: texts
234
243
  });
235
244
  });
236
245
  } else {
237
246
  (0, _hasManyText.transformHasManyText)({
238
247
  field,
239
- textRows: textPathMatch,
240
- ref: result
248
+ ref: result,
249
+ textRows: textPathMatch
241
250
  });
242
251
  }
243
252
  return result;
@@ -323,13 +332,16 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
323
332
  deletions,
324
333
  fieldPrefix: groupFieldPrefix,
325
334
  fields: field.fields,
326
- texts,
327
335
  numbers,
328
336
  path: `${sanitizedPath}${field.name}`,
329
337
  relationships,
330
- table
338
+ table,
339
+ texts
331
340
  });
332
341
  });
342
+ if ('_order' in ref) {
343
+ delete ref._order;
344
+ }
333
345
  } else {
334
346
  const groupData = {};
335
347
  ref[field.name] = traverseFields({
@@ -339,12 +351,15 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
339
351
  deletions,
340
352
  fieldPrefix: groupFieldPrefix,
341
353
  fields: field.fields,
342
- texts,
343
354
  numbers,
344
355
  path: `${sanitizedPath}${field.name}`,
345
356
  relationships,
346
- table
357
+ table,
358
+ texts
347
359
  });
360
+ if ('_order' in ref) {
361
+ delete ref._order;
362
+ }
348
363
  }
349
364
  break;
350
365
  }
@@ -411,4 +426,4 @@ const traverseFields = ({ blocks, config, dataRef, deletions, fieldPrefix, field
411
426
  return formatted;
412
427
  };
413
428
 
414
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/transform/read/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SanitizedConfig } from 'payload/config'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { fieldAffectsData } from 'payload/types'\n\nimport type { BlocksMap } from '../../utilities/createBlocksMap'\n\nimport { transformHasManyNumber } from './hasManyNumber'\nimport { transformRelationship } from './relationship'\nimport { transformHasManyText } from './hasManyText'\n\ntype TraverseFieldsArgs = {\n  /**\n   * Pre-formatted blocks map\n   */\n  blocks: BlocksMap\n  /**\n   * The full Payload config\n   */\n  config: SanitizedConfig\n  /**\n   * The data reference to be mutated within this recursive function\n   */\n  dataRef: Record<string, unknown>\n  /**\n   * Data that needs to be removed from the result after all fields have populated\n   */\n  deletions: (() => void)[]\n  /**\n   * Column prefix can be built up by group and named tab fields\n   */\n  fieldPrefix: string\n  /**\n   * An array of Payload fields to traverse\n   */\n  fields: (Field | TabAsField)[]\n  /**\n   * All hasMany text fields, as returned by Drizzle, keyed on an object by field path\n   */\n  texts: Record<string, Record<string, unknown>[]>\n  /**\n   * All hasMany number fields, as returned by Drizzle, keyed on an object by field path\n   */\n  numbers: Record<string, Record<string, unknown>[]>\n  /**\n   * The current field path (in dot notation), used to merge in relationships\n   */\n  path: string\n  /**\n   * All related documents, as returned by Drizzle, keyed on an object by field path\n   */\n  relationships: Record<string, Record<string, unknown>[]>\n  /**\n   * Data structure representing the nearest table from db\n   */\n  table: Record<string, unknown>\n}\n\n// Traverse fields recursively, transforming data\n// for each field type into required Payload shape\nexport const traverseFields = <T extends Record<string, unknown>>({\n  blocks,\n  config,\n  dataRef,\n  deletions,\n  fieldPrefix,\n  fields,\n  texts,\n  numbers,\n  path,\n  relationships,\n  table,\n}: TraverseFieldsArgs): T => {\n  const sanitizedPath = path ? `${path}.` : path\n\n  const formatted = fields.reduce((result, field) => {\n    if (field.type === 'tabs') {\n      traverseFields({\n        blocks,\n        config,\n        dataRef,\n        deletions,\n        fieldPrefix,\n        fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n        texts,\n        numbers,\n        path,\n        relationships,\n        table,\n      })\n    }\n\n    if (\n      field.type === 'collapsible' ||\n      field.type === 'row' ||\n      (field.type === 'tab' && !('name' in field))\n    ) {\n      traverseFields({\n        blocks,\n        config,\n        dataRef,\n        deletions,\n        fieldPrefix,\n        fields: field.fields,\n        texts,\n        numbers,\n        path,\n        relationships,\n        table,\n      })\n    }\n\n    if (fieldAffectsData(field)) {\n      const fieldName = `${fieldPrefix || ''}${field.name}`\n      const fieldData = table[fieldName]\n      if (field.type === 'array') {\n        if (Array.isArray(fieldData)) {\n          if (field.localized) {\n            result[field.name] = fieldData.reduce((arrayResult, row) => {\n              if (typeof row._locale === 'string') {\n                if (!arrayResult[row._locale]) arrayResult[row._locale] = []\n                const locale = row._locale\n                const data = {}\n                delete row._locale\n                if (row._uuid) {\n                  row.id = row._uuid\n                  delete row._uuid\n                }\n\n                const rowResult = traverseFields<T>({\n                  blocks,\n                  config,\n                  dataRef: data,\n                  deletions,\n                  fieldPrefix: '',\n                  fields: field.fields,\n                  texts,\n                  numbers,\n                  path: `${sanitizedPath}${field.name}.${row._order - 1}`,\n                  relationships,\n                  table: row,\n                })\n\n                arrayResult[locale].push(rowResult)\n              }\n\n              return arrayResult\n            }, {})\n          } else {\n            result[field.name] = fieldData.map((row, i) => {\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n              return traverseFields<T>({\n                blocks,\n                config,\n                dataRef: row,\n                deletions,\n                fieldPrefix: '',\n                fields: field.fields,\n                texts,\n                numbers,\n                path: `${sanitizedPath}${field.name}.${i}`,\n                relationships,\n                table: row,\n              })\n            })\n          }\n        }\n\n        return result\n      }\n\n      if (field.type === 'blocks') {\n        const blockFieldPath = `${sanitizedPath}${field.name}`\n\n        if (Array.isArray(blocks[blockFieldPath])) {\n          if (field.localized) {\n            result[field.name] = {}\n\n            blocks[blockFieldPath].forEach((row) => {\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n              if (typeof row._locale === 'string') {\n                if (!result[field.name][row._locale]) result[field.name][row._locale] = []\n                result[field.name][row._locale].push(row)\n                delete row._locale\n              }\n            })\n\n            Object.entries(result[field.name]).forEach(([locale, localizedBlocks]) => {\n              result[field.name][locale] = localizedBlocks.map((row) => {\n                const block = field.blocks.find(({ slug }) => slug === row.blockType)\n\n                if (block) {\n                  const blockResult = traverseFields<T>({\n                    blocks,\n                    config,\n                    dataRef: row,\n                    deletions,\n                    fieldPrefix: '',\n                    fields: block.fields,\n                    texts,\n                    numbers,\n                    path: `${blockFieldPath}.${row._order - 1}`,\n                    relationships,\n                    table: row,\n                  })\n\n                  delete blockResult._order\n                  return blockResult\n                }\n\n                return {}\n              })\n            })\n          } else {\n            result[field.name] = blocks[blockFieldPath].map((row, i) => {\n              delete row._order\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n              const block = field.blocks.find(({ slug }) => slug === row.blockType)\n\n              if (block) {\n                return traverseFields<T>({\n                  blocks,\n                  config,\n                  dataRef: row,\n                  deletions,\n                  fieldPrefix: '',\n                  fields: block.fields,\n                  texts,\n                  numbers,\n                  path: `${blockFieldPath}.${i}`,\n                  relationships,\n                  table: row,\n                })\n              }\n\n              return {}\n            })\n          }\n        }\n\n        return result\n      }\n\n      if (field.type === 'relationship' || field.type === 'upload') {\n        const relationPathMatch = relationships[`${sanitizedPath}${field.name}`]\n        if (!relationPathMatch) {\n          if ('hasMany' in field && field.hasMany) {\n            if (field.localized && config.localization && config.localization.locales) {\n              result[field.name] = {\n                [config.localization.defaultLocale]: [],\n              }\n            } else {\n              result[field.name] = []\n            }\n          }\n\n          return result\n        }\n\n        if (field.localized) {\n          result[field.name] = {}\n          const relationsByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          relationPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!relationsByLocale[row.locale]) relationsByLocale[row.locale] = []\n              relationsByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(relationsByLocale).forEach(([locale, relations]) => {\n            transformRelationship({\n              field,\n              locale,\n              ref: result,\n              relations,\n            })\n          })\n        } else {\n          transformRelationship({\n            field,\n            ref: result,\n            relations: relationPathMatch,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'text' && field?.hasMany) {\n        const textPathMatch = texts[`${sanitizedPath}${field.name}`]\n        if (!textPathMatch) return result\n\n        if (field.localized) {\n          result[field.name] = {}\n          const textsByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          textPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!textsByLocale[row.locale]) textsByLocale[row.locale] = []\n              textsByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(textsByLocale).forEach(([locale, texts]) => {\n            transformHasManyText({\n              field,\n              locale,\n              textRows: texts,\n              ref: result,\n            })\n          })\n        } else {\n          transformHasManyText({\n            field,\n            textRows: textPathMatch,\n            ref: result,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'number' && field.hasMany) {\n        const numberPathMatch = numbers[`${sanitizedPath}${field.name}`]\n        if (!numberPathMatch) return result\n\n        if (field.localized) {\n          result[field.name] = {}\n          const numbersByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          numberPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!numbersByLocale[row.locale]) numbersByLocale[row.locale] = []\n              numbersByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(numbersByLocale).forEach(([locale, numbers]) => {\n            transformHasManyNumber({\n              field,\n              locale,\n              numberRows: numbers,\n              ref: result,\n            })\n          })\n        } else {\n          transformHasManyNumber({\n            field,\n            numberRows: numberPathMatch,\n            ref: result,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'select' && field.hasMany) {\n        if (Array.isArray(fieldData)) {\n          if (field.localized) {\n            result[field.name] = fieldData.reduce((selectResult, row) => {\n              if (typeof row.locale === 'string') {\n                if (!selectResult[row.locale]) selectResult[row.locale] = []\n                selectResult[row.locale].push(row.value)\n              }\n\n              return selectResult\n            }, {})\n          } else {\n            result[field.name] = fieldData.map(({ value }) => value)\n          }\n        }\n        return result\n      }\n\n      const localizedFieldData = {}\n      const valuesToTransform: {\n        ref: Record<string, unknown>\n        table: Record<string, unknown>\n      }[] = []\n\n      if (field.localized && Array.isArray(table._locales)) {\n        table._locales.forEach((localeRow) => {\n          valuesToTransform.push({ ref: localizedFieldData, table: localeRow })\n        })\n      } else {\n        valuesToTransform.push({ ref: result, table })\n      }\n\n      valuesToTransform.forEach(({ ref, table }) => {\n        const fieldData = table[`${fieldPrefix || ''}${field.name}`]\n        const locale = table?._locale\n\n        switch (field.type) {\n          case 'tab':\n          case 'group': {\n            const groupFieldPrefix = `${fieldPrefix || ''}${field.name}_`\n\n            if (field.localized) {\n              if (typeof locale === 'string' && !ref[locale]) {\n                ref[locale] = {}\n                delete table._locale\n              }\n\n              Object.entries(ref).forEach(([groupLocale, groupLocaleData]) => {\n                ref[groupLocale] = traverseFields<Record<string, unknown>>({\n                  blocks,\n                  config,\n                  dataRef: groupLocaleData as Record<string, unknown>,\n                  deletions,\n                  fieldPrefix: groupFieldPrefix,\n                  fields: field.fields,\n                  texts,\n                  numbers,\n                  path: `${sanitizedPath}${field.name}`,\n                  relationships,\n                  table,\n                })\n              })\n            } else {\n              const groupData = {}\n\n              ref[field.name] = traverseFields<Record<string, unknown>>({\n                blocks,\n                config,\n                dataRef: groupData as Record<string, unknown>,\n                deletions,\n                fieldPrefix: groupFieldPrefix,\n                fields: field.fields,\n                texts,\n                numbers,\n                path: `${sanitizedPath}${field.name}`,\n                relationships,\n                table,\n              })\n            }\n\n            break\n          }\n\n          case 'text': {\n            let val = fieldData\n            if (typeof fieldData === 'string') {\n              val = String(fieldData)\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          case 'number': {\n            let val = fieldData\n            if (typeof fieldData === 'string') {\n              val = Number.parseFloat(fieldData)\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          case 'date': {\n            let val = fieldData\n\n            if (typeof fieldData === 'string') {\n              val = new Date(fieldData).toISOString()\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          default: {\n            if (typeof locale === 'string') {\n              ref[locale] = fieldData\n            } else {\n              result[field.name] = fieldData\n            }\n\n            break\n          }\n        }\n      })\n\n      if (Object.keys(localizedFieldData).length > 0) {\n        result[field.name] = localizedFieldData\n      }\n\n      return result\n    }\n\n    return result\n  }, dataRef)\n\n  if (Array.isArray(table._locales)) {\n    deletions.push(() => delete table._locales)\n  }\n\n  return formatted as T\n}\n"],"names":["traverseFields","blocks","config","dataRef","deletions","fieldPrefix","fields","texts","numbers","path","relationships","table","sanitizedPath","formatted","reduce","result","field","type","tabs","map","tab","fieldAffectsData","fieldName","name","fieldData","Array","isArray","localized","arrayResult","row","_locale","locale","data","_uuid","id","rowResult","_order","push","i","blockFieldPath","forEach","Object","entries","localizedBlocks","block","find","slug","blockType","blockResult","relationPathMatch","hasMany","localization","locales","defaultLocale","relationsByLocale","relations","transformRelationship","ref","textPathMatch","textsByLocale","transformHasManyText","textRows","numberPathMatch","numbersByLocale","transformHasManyNumber","numberRows","selectResult","value","localizedFieldData","valuesToTransform","_locales","localeRow","groupFieldPrefix","groupLocale","groupLocaleData","groupData","val","String","Number","parseFloat","Date","toISOString","keys","length"],"mappings":"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"}
429
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/transform/read/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SanitizedConfig } from 'payload/config'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { fieldAffectsData } from 'payload/types'\n\nimport type { BlocksMap } from '../../utilities/createBlocksMap'\n\nimport { transformHasManyNumber } from './hasManyNumber'\nimport { transformHasManyText } from './hasManyText'\nimport { transformRelationship } from './relationship'\n\ntype TraverseFieldsArgs = {\n  /**\n   * Pre-formatted blocks map\n   */\n  blocks: BlocksMap\n  /**\n   * The full Payload config\n   */\n  config: SanitizedConfig\n  /**\n   * The data reference to be mutated within this recursive function\n   */\n  dataRef: Record<string, unknown>\n  /**\n   * Data that needs to be removed from the result after all fields have populated\n   */\n  deletions: (() => void)[]\n  /**\n   * Column prefix can be built up by group and named tab fields\n   */\n  fieldPrefix: string\n  /**\n   * An array of Payload fields to traverse\n   */\n  fields: (Field | TabAsField)[]\n  /**\n   * All hasMany number fields, as returned by Drizzle, keyed on an object by field path\n   */\n  numbers: Record<string, Record<string, unknown>[]>\n  /**\n   * The current field path (in dot notation), used to merge in relationships\n   */\n  path: string\n  /**\n   * All related documents, as returned by Drizzle, keyed on an object by field path\n   */\n  relationships: Record<string, Record<string, unknown>[]>\n  /**\n   * Data structure representing the nearest table from db\n   */\n  table: Record<string, unknown>\n  /**\n   * All hasMany text fields, as returned by Drizzle, keyed on an object by field path\n   */\n  texts: Record<string, Record<string, unknown>[]>\n}\n\n// Traverse fields recursively, transforming data\n// for each field type into required Payload shape\nexport const traverseFields = <T extends Record<string, unknown>>({\n  blocks,\n  config,\n  dataRef,\n  deletions,\n  fieldPrefix,\n  fields,\n  numbers,\n  path,\n  relationships,\n  table,\n  texts,\n}: TraverseFieldsArgs): T => {\n  const sanitizedPath = path ? `${path}.` : path\n\n  const formatted = fields.reduce((result, field) => {\n    if (field.type === 'tabs') {\n      traverseFields({\n        blocks,\n        config,\n        dataRef,\n        deletions,\n        fieldPrefix,\n        fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n        numbers,\n        path,\n        relationships,\n        table,\n        texts,\n      })\n    }\n\n    if (\n      field.type === 'collapsible' ||\n      field.type === 'row' ||\n      (field.type === 'tab' && !('name' in field))\n    ) {\n      traverseFields({\n        blocks,\n        config,\n        dataRef,\n        deletions,\n        fieldPrefix,\n        fields: field.fields,\n        numbers,\n        path,\n        relationships,\n        table,\n        texts,\n      })\n    }\n\n    if (fieldAffectsData(field)) {\n      const fieldName = `${fieldPrefix || ''}${field.name}`\n      const fieldData = table[fieldName]\n\n      if (fieldPrefix) {\n        deletions.push(() => delete table[fieldName])\n      }\n\n      if (field.type === 'array') {\n        if (Array.isArray(fieldData)) {\n          if (field.localized) {\n            result[field.name] = fieldData.reduce((arrayResult, row) => {\n              if (typeof row._locale === 'string') {\n                if (!arrayResult[row._locale]) arrayResult[row._locale] = []\n                const locale = row._locale\n                const data = {}\n                delete row._locale\n                if (row._uuid) {\n                  row.id = row._uuid\n                  delete row._uuid\n                }\n\n                const rowResult = traverseFields<T>({\n                  blocks,\n                  config,\n                  dataRef: data,\n                  deletions,\n                  fieldPrefix: '',\n                  fields: field.fields,\n                  numbers,\n                  path: `${sanitizedPath}${field.name}.${row._order - 1}`,\n                  relationships,\n                  table: row,\n                  texts,\n                })\n\n                if ('_order' in rowResult) {\n                  delete rowResult._order\n                }\n\n                arrayResult[locale].push(rowResult)\n              }\n\n              return arrayResult\n            }, {})\n          } else {\n            result[field.name] = fieldData.map((row, i) => {\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n\n              if ('_order' in row) {\n                delete row._order\n              }\n\n              return traverseFields<T>({\n                blocks,\n                config,\n                dataRef: row,\n                deletions,\n                fieldPrefix: '',\n                fields: field.fields,\n                numbers,\n                path: `${sanitizedPath}${field.name}.${i}`,\n                relationships,\n                table: row,\n                texts,\n              })\n            })\n          }\n        }\n\n        return result\n      }\n\n      if (field.type === 'blocks') {\n        const blockFieldPath = `${sanitizedPath}${field.name}`\n\n        if (Array.isArray(blocks[blockFieldPath])) {\n          if (field.localized) {\n            result[field.name] = {}\n\n            blocks[blockFieldPath].forEach((row) => {\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n              if (typeof row._locale === 'string') {\n                if (!result[field.name][row._locale]) result[field.name][row._locale] = []\n                result[field.name][row._locale].push(row)\n                delete row._locale\n              }\n            })\n\n            Object.entries(result[field.name]).forEach(([locale, localizedBlocks]) => {\n              result[field.name][locale] = localizedBlocks.map((row) => {\n                const block = field.blocks.find(({ slug }) => slug === row.blockType)\n\n                if (block) {\n                  const blockResult = traverseFields<T>({\n                    blocks,\n                    config,\n                    dataRef: row,\n                    deletions,\n                    fieldPrefix: '',\n                    fields: block.fields,\n                    numbers,\n                    path: `${blockFieldPath}.${row._order - 1}`,\n                    relationships,\n                    table: row,\n                    texts,\n                  })\n\n                  delete blockResult._order\n                  return blockResult\n                }\n\n                return {}\n              })\n            })\n          } else {\n            result[field.name] = blocks[blockFieldPath].map((row, i) => {\n              delete row._order\n              if (row._uuid) {\n                row.id = row._uuid\n                delete row._uuid\n              }\n              const block = field.blocks.find(({ slug }) => slug === row.blockType)\n\n              if (block) {\n                return traverseFields<T>({\n                  blocks,\n                  config,\n                  dataRef: row,\n                  deletions,\n                  fieldPrefix: '',\n                  fields: block.fields,\n                  numbers,\n                  path: `${blockFieldPath}.${i}`,\n                  relationships,\n                  table: row,\n                  texts,\n                })\n              }\n\n              return {}\n            })\n          }\n        }\n\n        return result\n      }\n\n      if (field.type === 'relationship' || field.type === 'upload') {\n        const relationPathMatch = relationships[`${sanitizedPath}${field.name}`]\n        if (!relationPathMatch) {\n          if ('hasMany' in field && field.hasMany) {\n            if (field.localized && config.localization && config.localization.locales) {\n              result[field.name] = {\n                [config.localization.defaultLocale]: [],\n              }\n            } else {\n              result[field.name] = []\n            }\n          }\n\n          return result\n        }\n\n        if (field.localized) {\n          result[field.name] = {}\n          const relationsByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          relationPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!relationsByLocale[row.locale]) relationsByLocale[row.locale] = []\n              relationsByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(relationsByLocale).forEach(([locale, relations]) => {\n            transformRelationship({\n              field,\n              locale,\n              ref: result,\n              relations,\n            })\n          })\n        } else {\n          transformRelationship({\n            field,\n            ref: result,\n            relations: relationPathMatch,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'text' && field?.hasMany) {\n        const textPathMatch = texts[`${sanitizedPath}${field.name}`]\n        if (!textPathMatch) return result\n\n        if (field.localized) {\n          result[field.name] = {}\n          const textsByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          textPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!textsByLocale[row.locale]) textsByLocale[row.locale] = []\n              textsByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(textsByLocale).forEach(([locale, texts]) => {\n            transformHasManyText({\n              field,\n              locale,\n              ref: result,\n              textRows: texts,\n            })\n          })\n        } else {\n          transformHasManyText({\n            field,\n            ref: result,\n            textRows: textPathMatch,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'number' && field.hasMany) {\n        const numberPathMatch = numbers[`${sanitizedPath}${field.name}`]\n        if (!numberPathMatch) return result\n\n        if (field.localized) {\n          result[field.name] = {}\n          const numbersByLocale: Record<string, Record<string, unknown>[]> = {}\n\n          numberPathMatch.forEach((row) => {\n            if (typeof row.locale === 'string') {\n              if (!numbersByLocale[row.locale]) numbersByLocale[row.locale] = []\n              numbersByLocale[row.locale].push(row)\n            }\n          })\n\n          Object.entries(numbersByLocale).forEach(([locale, numbers]) => {\n            transformHasManyNumber({\n              field,\n              locale,\n              numberRows: numbers,\n              ref: result,\n            })\n          })\n        } else {\n          transformHasManyNumber({\n            field,\n            numberRows: numberPathMatch,\n            ref: result,\n          })\n        }\n\n        return result\n      }\n\n      if (field.type === 'select' && field.hasMany) {\n        if (Array.isArray(fieldData)) {\n          if (field.localized) {\n            result[field.name] = fieldData.reduce((selectResult, row) => {\n              if (typeof row.locale === 'string') {\n                if (!selectResult[row.locale]) selectResult[row.locale] = []\n                selectResult[row.locale].push(row.value)\n              }\n\n              return selectResult\n            }, {})\n          } else {\n            result[field.name] = fieldData.map(({ value }) => value)\n          }\n        }\n        return result\n      }\n\n      const localizedFieldData = {}\n      const valuesToTransform: {\n        ref: Record<string, unknown>\n        table: Record<string, unknown>\n      }[] = []\n\n      if (field.localized && Array.isArray(table._locales)) {\n        table._locales.forEach((localeRow) => {\n          valuesToTransform.push({ ref: localizedFieldData, table: localeRow })\n        })\n      } else {\n        valuesToTransform.push({ ref: result, table })\n      }\n\n      valuesToTransform.forEach(({ ref, table }) => {\n        const fieldData = table[`${fieldPrefix || ''}${field.name}`]\n        const locale = table?._locale\n\n        switch (field.type) {\n          case 'tab':\n          case 'group': {\n            const groupFieldPrefix = `${fieldPrefix || ''}${field.name}_`\n\n            if (field.localized) {\n              if (typeof locale === 'string' && !ref[locale]) {\n                ref[locale] = {}\n                delete table._locale\n              }\n\n              Object.entries(ref).forEach(([groupLocale, groupLocaleData]) => {\n                ref[groupLocale] = traverseFields<Record<string, unknown>>({\n                  blocks,\n                  config,\n                  dataRef: groupLocaleData as Record<string, unknown>,\n                  deletions,\n                  fieldPrefix: groupFieldPrefix,\n                  fields: field.fields,\n                  numbers,\n                  path: `${sanitizedPath}${field.name}`,\n                  relationships,\n                  table,\n                  texts,\n                })\n              })\n              if ('_order' in ref) {\n                delete ref._order\n              }\n            } else {\n              const groupData = {}\n\n              ref[field.name] = traverseFields<Record<string, unknown>>({\n                blocks,\n                config,\n                dataRef: groupData as Record<string, unknown>,\n                deletions,\n                fieldPrefix: groupFieldPrefix,\n                fields: field.fields,\n                numbers,\n                path: `${sanitizedPath}${field.name}`,\n                relationships,\n                table,\n                texts,\n              })\n              if ('_order' in ref) {\n                delete ref._order\n              }\n            }\n\n            break\n          }\n\n          case 'text': {\n            let val = fieldData\n            if (typeof fieldData === 'string') {\n              val = String(fieldData)\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          case 'number': {\n            let val = fieldData\n            if (typeof fieldData === 'string') {\n              val = Number.parseFloat(fieldData)\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          case 'date': {\n            let val = fieldData\n\n            if (typeof fieldData === 'string') {\n              val = new Date(fieldData).toISOString()\n            }\n\n            if (typeof locale === 'string') {\n              ref[locale] = val\n            } else {\n              result[field.name] = val\n            }\n\n            break\n          }\n\n          default: {\n            if (typeof locale === 'string') {\n              ref[locale] = fieldData\n            } else {\n              result[field.name] = fieldData\n            }\n\n            break\n          }\n        }\n      })\n\n      if (Object.keys(localizedFieldData).length > 0) {\n        result[field.name] = localizedFieldData\n      }\n\n      return result\n    }\n\n    return result\n  }, dataRef)\n\n  if (Array.isArray(table._locales)) {\n    deletions.push(() => delete table._locales)\n  }\n\n  return formatted as T\n}\n"],"names":["traverseFields","blocks","config","dataRef","deletions","fieldPrefix","fields","numbers","path","relationships","table","texts","sanitizedPath","formatted","reduce","result","field","type","tabs","map","tab","fieldAffectsData","fieldName","name","fieldData","push","Array","isArray","localized","arrayResult","row","_locale","locale","data","_uuid","id","rowResult","_order","i","blockFieldPath","forEach","Object","entries","localizedBlocks","block","find","slug","blockType","blockResult","relationPathMatch","hasMany","localization","locales","defaultLocale","relationsByLocale","relations","transformRelationship","ref","textPathMatch","textsByLocale","transformHasManyText","textRows","numberPathMatch","numbersByLocale","transformHasManyNumber","numberRows","selectResult","value","localizedFieldData","valuesToTransform","_locales","localeRow","groupFieldPrefix","groupLocale","groupLocaleData","groupData","val","String","Number","parseFloat","Date","toISOString","keys","length"],"mappings":"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"}