@payloadcms/db-postgres 0.2.3 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (54) hide show
  1. package/dist/find/buildFindManyArgs.d.ts.map +1 -1
  2. package/dist/find/buildFindManyArgs.js +12 -1
  3. package/dist/init.d.ts.map +1 -1
  4. package/dist/init.js +7 -1
  5. package/dist/migrate.d.ts.map +1 -1
  6. package/dist/migrate.js +14 -5
  7. package/dist/migrateDown.d.ts.map +1 -1
  8. package/dist/migrateDown.js +13 -10
  9. package/dist/migrateFresh.d.ts.map +1 -1
  10. package/dist/migrateFresh.js +15 -12
  11. package/dist/migrateRefresh.d.ts.map +1 -1
  12. package/dist/migrateRefresh.js +17 -15
  13. package/dist/migrateReset.d.ts.map +1 -1
  14. package/dist/migrateReset.js +11 -9
  15. package/dist/queries/parseParams.d.ts.map +1 -1
  16. package/dist/queries/parseParams.js +29 -5
  17. package/dist/schema/build.d.ts +3 -1
  18. package/dist/schema/build.d.ts.map +1 -1
  19. package/dist/schema/build.js +58 -17
  20. package/dist/schema/getConfigIDType.d.ts +3 -0
  21. package/dist/schema/getConfigIDType.d.ts.map +1 -0
  22. package/dist/schema/getConfigIDType.js +25 -0
  23. package/dist/schema/traverseFields.d.ts +4 -1
  24. package/dist/schema/traverseFields.d.ts.map +1 -1
  25. package/dist/schema/traverseFields.js +48 -8
  26. package/dist/schema/validateExistingBlockIsIdentical.d.ts.map +1 -1
  27. package/dist/schema/validateExistingBlockIsIdentical.js +49 -7
  28. package/dist/transform/read/hasManyText.d.ts +10 -0
  29. package/dist/transform/read/hasManyText.d.ts.map +1 -0
  30. package/dist/transform/read/hasManyText.js +20 -0
  31. package/dist/transform/read/index.d.ts.map +1 -1
  32. package/dist/transform/read/index.js +7 -1
  33. package/dist/transform/read/traverseFields.d.ts +5 -1
  34. package/dist/transform/read/traverseFields.d.ts.map +1 -1
  35. package/dist/transform/read/traverseFields.js +53 -2
  36. package/dist/transform/write/array.d.ts +2 -1
  37. package/dist/transform/write/array.d.ts.map +1 -1
  38. package/dist/transform/write/array.js +3 -2
  39. package/dist/transform/write/blocks.d.ts +2 -1
  40. package/dist/transform/write/blocks.d.ts.map +1 -1
  41. package/dist/transform/write/blocks.js +3 -2
  42. package/dist/transform/write/index.d.ts.map +1 -1
  43. package/dist/transform/write/index.js +3 -1
  44. package/dist/transform/write/texts.d.ts +8 -0
  45. package/dist/transform/write/texts.d.ts.map +1 -0
  46. package/dist/transform/write/texts.js +21 -0
  47. package/dist/transform/write/traverseFields.d.ts +2 -1
  48. package/dist/transform/write/traverseFields.d.ts.map +1 -1
  49. package/dist/transform/write/traverseFields.js +41 -2
  50. package/dist/transform/write/types.d.ts +1 -0
  51. package/dist/transform/write/types.d.ts.map +1 -1
  52. package/dist/upsertRow/index.d.ts.map +1 -1
  53. package/dist/upsertRow/index.js +28 -1
  54. package/package.json +3 -3
@@ -24,9 +24,11 @@ function _interop_require_default(obj) {
24
24
  default: obj
25
25
  };
26
26
  }
27
- const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique = false, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName })=>{
27
+ const traverseFields = ({ adapter, buildTexts, buildNumbers, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique = false, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName })=>{
28
28
  let hasLocalizedField = false;
29
29
  let hasLocalizedRelationshipField = false;
30
+ let hasManyTextField = false;
31
+ let hasLocalizedManyTextField = false;
30
32
  let hasManyNumberField = false;
31
33
  let hasLocalizedManyNumberField = false;
32
34
  let parentIDColType = 'integer';
@@ -73,6 +75,24 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
73
75
  }
74
76
  switch(field.type){
75
77
  case 'text':
78
+ {
79
+ if (field.hasMany) {
80
+ if (field.localized) {
81
+ hasLocalizedManyTextField = true;
82
+ }
83
+ if (field.index) {
84
+ hasManyTextField = 'index';
85
+ } else if (!hasManyTextField) {
86
+ hasManyTextField = true;
87
+ }
88
+ if (field.unique) {
89
+ throw new _errors.InvalidConfiguration('Unique is not supported in Postgres for hasMany text fields.');
90
+ }
91
+ } else {
92
+ targetTable[fieldName] = (0, _pgcore.varchar)(columnName);
93
+ }
94
+ break;
95
+ }
76
96
  case 'email':
77
97
  case 'code':
78
98
  case 'textarea':
@@ -200,7 +220,7 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
200
220
  baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
201
221
  baseExtraConfig._localeIdx = (cols)=>(0, _pgcore.index)('_locale_idx').on(cols._locale);
202
222
  }
203
- const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
223
+ const { hasManyTextField: subHasManyTextField, hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
204
224
  adapter,
205
225
  baseColumns,
206
226
  baseExtraConfig,
@@ -213,6 +233,9 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
213
233
  rootTableName,
214
234
  tableName: arrayTableName
215
235
  });
236
+ if (subHasManyTextField) {
237
+ if (!hasManyTextField || subHasManyTextField === 'index') hasManyTextField = subHasManyTextField;
238
+ }
216
239
  if (subHasManyNumberField) {
217
240
  if (!hasManyNumberField || subHasManyNumberField === 'index') hasManyNumberField = subHasManyNumberField;
218
241
  }
@@ -261,7 +284,7 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
261
284
  baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
262
285
  baseExtraConfig._localeIdx = (cols)=>(0, _pgcore.index)('locale_idx').on(cols._locale);
263
286
  }
264
- const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
287
+ const { hasManyTextField: subHasManyTextField, hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
265
288
  adapter,
266
289
  baseColumns,
267
290
  baseExtraConfig,
@@ -274,6 +297,9 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
274
297
  rootTableName,
275
298
  tableName: blockTableName
276
299
  });
300
+ if (subHasManyTextField) {
301
+ if (!hasManyTextField || subHasManyTextField === 'index') hasManyTextField = subHasManyTextField;
302
+ }
277
303
  if (subHasManyNumberField) {
278
304
  if (!hasManyNumberField || subHasManyNumberField === 'index') hasManyNumberField = subHasManyNumberField;
279
305
  }
@@ -313,8 +339,9 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
313
339
  case 'group':
314
340
  {
315
341
  if (!('name' in field)) {
316
- const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
342
+ const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyTextField: groupHasLocalizedManyTextField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyTextField: groupHasManyTextField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
317
343
  adapter,
344
+ buildTexts,
318
345
  buildNumbers,
319
346
  buildRelationships,
320
347
  columnPrefix,
@@ -337,13 +364,16 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
337
364
  });
338
365
  if (groupHasLocalizedField) hasLocalizedField = true;
339
366
  if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
367
+ if (groupHasManyTextField) hasManyTextField = true;
368
+ if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true;
340
369
  if (groupHasManyNumberField) hasManyNumberField = true;
341
370
  if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
342
371
  break;
343
372
  }
344
373
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
345
- const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
374
+ const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyTextField: groupHasLocalizedManyTextField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyTextField: groupHasManyTextField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
346
375
  adapter,
376
+ buildTexts,
347
377
  buildNumbers,
348
378
  buildRelationships,
349
379
  columnPrefix: `${columnName}_`,
@@ -366,6 +396,8 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
366
396
  });
367
397
  if (groupHasLocalizedField) hasLocalizedField = true;
368
398
  if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
399
+ if (groupHasManyTextField) hasManyTextField = true;
400
+ if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true;
369
401
  if (groupHasManyNumberField) hasManyNumberField = true;
370
402
  if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
371
403
  break;
@@ -373,8 +405,9 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
373
405
  case 'tabs':
374
406
  {
375
407
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
376
- const { hasLocalizedField: tabHasLocalizedField, hasLocalizedManyNumberField: tabHasLocalizedManyNumberField, hasLocalizedRelationshipField: tabHasLocalizedRelationshipField, hasManyNumberField: tabHasManyNumberField } = traverseFields({
408
+ const { hasLocalizedField: tabHasLocalizedField, hasLocalizedManyTextField: tabHasLocalizedManyTextField, hasLocalizedManyNumberField: tabHasLocalizedManyNumberField, hasLocalizedRelationshipField: tabHasLocalizedRelationshipField, hasManyTextField: tabHasManyTextField, hasManyNumberField: tabHasManyNumberField } = traverseFields({
377
409
  adapter,
410
+ buildTexts,
378
411
  buildNumbers,
379
412
  buildRelationships,
380
413
  columnPrefix,
@@ -400,6 +433,8 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
400
433
  });
401
434
  if (tabHasLocalizedField) hasLocalizedField = true;
402
435
  if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
436
+ if (tabHasManyTextField) hasManyTextField = true;
437
+ if (tabHasLocalizedManyTextField) hasLocalizedManyTextField = true;
403
438
  if (tabHasManyNumberField) hasManyNumberField = true;
404
439
  if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
405
440
  break;
@@ -408,8 +443,9 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
408
443
  case 'collapsible':
409
444
  {
410
445
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
411
- const { hasLocalizedField: rowHasLocalizedField, hasLocalizedManyNumberField: rowHasLocalizedManyNumberField, hasLocalizedRelationshipField: rowHasLocalizedRelationshipField, hasManyNumberField: rowHasManyNumberField } = traverseFields({
446
+ const { hasLocalizedField: rowHasLocalizedField, hasLocalizedManyTextField: rowHasLocalizedManyTextField, hasLocalizedManyNumberField: rowHasLocalizedManyNumberField, hasLocalizedRelationshipField: rowHasLocalizedRelationshipField, hasManyTextField: rowHasManyTextField, hasManyNumberField: rowHasManyNumberField } = traverseFields({
412
447
  adapter,
448
+ buildTexts,
413
449
  buildNumbers,
414
450
  buildRelationships,
415
451
  columnPrefix,
@@ -432,6 +468,8 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
432
468
  });
433
469
  if (rowHasLocalizedField) hasLocalizedField = true;
434
470
  if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
471
+ if (rowHasManyTextField) hasManyTextField = true;
472
+ if (rowHasLocalizedManyTextField) hasLocalizedManyTextField = true;
435
473
  if (rowHasManyNumberField) hasManyNumberField = true;
436
474
  if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
437
475
  break;
@@ -457,10 +495,12 @@ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefi
457
495
  });
458
496
  return {
459
497
  hasLocalizedField,
498
+ hasLocalizedManyTextField,
460
499
  hasLocalizedManyNumberField,
461
500
  hasLocalizedRelationshipField,
501
+ hasManyTextField,
462
502
  hasManyNumberField
463
503
  };
464
504
  };
465
505
 
466
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { idToUUID } from './idToUUID'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildNumbers: boolean\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildNumbers,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        const unique = disableUnique !== true && field.unique\n        if (unique) {\n          const constraintValue = `${fieldPrefix || ''}${field.name}`\n          if (!adapter.fieldConstraints?.[rootTableName]) {\n            adapter.fieldConstraints[rootTableName] = {}\n          }\n          adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n        }\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } =\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull: disableNotNullFromHere,\n            disableUnique,\n            fields: disableUnique ? idToUUID(field.fields) : field.fields,\n            rootRelationsToBuild,\n            rootRelationships: relationships,\n            rootTableIDColType,\n            rootTableName,\n            tableName: arrayTableName,\n          })\n\n        if (subHasManyNumberField) {\n          if (!hasManyNumberField || subHasManyNumberField === 'index')\n            hasManyNumberField = subHasManyNumberField\n        }\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const {\n              hasManyNumberField: subHasManyNumberField,\n              relationsToBuild: subRelationsToBuild,\n            } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull: disableNotNullFromHere,\n              disableUnique,\n              fields: disableUnique ? idToUUID(block.fields) : block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            if (subHasManyNumberField) {\n              if (!hasManyNumberField || subHasManyNumberField === 'index')\n                hasManyNumberField = subHasManyNumberField\n            }\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildNumbers,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix: `${fieldName}.`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildNumbers","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","replace","payload","config","localization","localized","unique","index","includes","type","hasMany","constraintValue","fieldConstraints","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subHasManyNumberField","subRelationsToBuild","idToUUID","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","required"],"mappings":"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"}
506
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { idToUUID } from './idToUUID'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildTexts: boolean\n  buildNumbers: boolean\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyTextField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyTextField: 'index' | boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildTexts,\n  buildNumbers,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyTextField: 'index' | boolean = false\n  let hasLocalizedManyTextField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        const unique = disableUnique !== true && field.unique\n        if (unique) {\n          const constraintValue = `${fieldPrefix || ''}${field.name}`\n          if (!adapter.fieldConstraints?.[rootTableName]) {\n            adapter.fieldConstraints[rootTableName] = {}\n          }\n          adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n        }\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyTextField = true\n          }\n\n          if (field.index) {\n            hasManyTextField = 'index'\n          } else if (!hasManyTextField) {\n            hasManyTextField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany text fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = varchar(columnName)\n        }\n        break\n      }\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const {\n          hasManyTextField: subHasManyTextField,\n          hasManyNumberField: subHasManyNumberField,\n          relationsToBuild: subRelationsToBuild,\n        } = buildTable({\n          adapter,\n          baseColumns,\n          baseExtraConfig,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fields: disableUnique ? idToUUID(field.fields) : field.fields,\n          rootRelationsToBuild,\n          rootRelationships: relationships,\n          rootTableIDColType,\n          rootTableName,\n          tableName: arrayTableName,\n        })\n\n        if (subHasManyTextField) {\n          if (!hasManyTextField || subHasManyTextField === 'index')\n            hasManyTextField = subHasManyTextField\n        }\n        if (subHasManyNumberField) {\n          if (!hasManyNumberField || subHasManyNumberField === 'index')\n            hasManyNumberField = subHasManyNumberField\n        }\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const {\n              hasManyTextField: subHasManyTextField,\n              hasManyNumberField: subHasManyNumberField,\n              relationsToBuild: subRelationsToBuild,\n            } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull: disableNotNullFromHere,\n              disableUnique,\n              fields: disableUnique ? idToUUID(block.fields) : block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            if (subHasManyTextField) {\n              if (!hasManyTextField || subHasManyTextField === 'index')\n                hasManyTextField = subHasManyTextField\n            }\n\n            if (subHasManyNumberField) {\n              if (!hasManyNumberField || subHasManyNumberField === 'index')\n                hasManyNumberField = subHasManyNumberField\n            }\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyTextField: groupHasManyTextField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildTexts,\n            buildNumbers,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyTextField) hasManyTextField = true\n          if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyTextField: groupHasLocalizedManyTextField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyTextField: groupHasManyTextField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildTexts,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix: `${fieldName}.`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyTextField) hasManyTextField = true\n        if (groupHasLocalizedManyTextField) hasLocalizedManyTextField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyTextField: tabHasLocalizedManyTextField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyTextField: tabHasManyTextField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildTexts,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyTextField) hasManyTextField = true\n        if (tabHasLocalizedManyTextField) hasLocalizedManyTextField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyTextField: rowHasLocalizedManyTextField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyTextField: rowHasManyTextField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildTexts,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyTextField) hasManyTextField = true\n        if (rowHasLocalizedManyTextField) hasLocalizedManyTextField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyTextField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyTextField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildTexts","buildNumbers","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasLocalizedManyTextField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","replace","payload","config","localization","localized","unique","index","includes","type","hasMany","constraintValue","fieldConstraints","createIndex","InvalidConfiguration","varchar","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subHasManyTextField","subHasManyNumberField","subRelationsToBuild","idToUUID","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyTextField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyTextField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyTextField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyTextField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyTextField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyTextField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","required"],"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,EAAE,MAAM,eAAe,CAAA;AAK1C,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;AAED,eAAO,MAAM,gCAAgC,gDAK1C,IAAI,KAAG,IAoBT,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;AAsCD,eAAO,MAAM,gCAAgC,gDAK1C,IAAI,KAAG,IA0BT,CAAA"}
@@ -9,11 +9,52 @@ Object.defineProperty(exports, "validateExistingBlockIsIdentical", {
9
9
  }
10
10
  });
11
11
  const _errors = require("payload/errors");
12
- const _utilities = require("payload/utilities");
12
+ const _types = require("payload/types");
13
+ const getFlattenedFieldNames = (fields, prefix = '')=>{
14
+ return fields.reduce((fieldsToUse, field)=>{
15
+ let fieldPrefix = prefix;
16
+ if (field.type === 'blocks') {
17
+ return fieldsToUse;
18
+ }
19
+ if ((0, _types.fieldHasSubFields)(field)) {
20
+ fieldPrefix = 'name' in field ? `${prefix}${field.name}.` : prefix;
21
+ return [
22
+ ...fieldsToUse,
23
+ ...getFlattenedFieldNames(field.fields, fieldPrefix)
24
+ ];
25
+ }
26
+ if (field.type === 'tabs') {
27
+ return [
28
+ ...fieldsToUse,
29
+ ...field.tabs.reduce((tabFields, tab)=>{
30
+ fieldPrefix = 'name' in tab ? `${prefix}.${tab.name}` : prefix;
31
+ return [
32
+ ...tabFields,
33
+ ...(0, _types.tabHasName)(tab) ? [
34
+ {
35
+ ...tab,
36
+ type: 'tab'
37
+ }
38
+ ] : getFlattenedFieldNames(tab.fields, fieldPrefix)
39
+ ];
40
+ }, [])
41
+ ];
42
+ }
43
+ if ((0, _types.fieldAffectsData)(field)) {
44
+ return [
45
+ ...fieldsToUse,
46
+ `${fieldPrefix?.replace('.', '_') || ''}${field.name}`
47
+ ];
48
+ }
49
+ return fieldsToUse;
50
+ }, []);
51
+ };
13
52
  const validateExistingBlockIsIdentical = ({ block, localized, rootTableName, table })=>{
14
53
  if (table) {
15
- const fieldNames = (0, _utilities.flattenTopLevelFields)(block.fields).flatMap((field)=>field.name);
16
- Object.keys(table).forEach((fieldName)=>{
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)=>{
17
58
  if (![
18
59
  '_locale',
19
60
  '_order',
@@ -21,15 +62,16 @@ const validateExistingBlockIsIdentical = ({ block, localized, rootTableName, tab
21
62
  '_path',
22
63
  '_uuid'
23
64
  ].includes(fieldName)) {
24
- if (fieldNames.indexOf(fieldName) === -1) {
25
- 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 ${fieldName}, while the other block does not.`);
26
- }
65
+ return fieldNames.indexOf(fieldName) === -1;
27
66
  }
28
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
+ }
29
71
  if (Boolean(localized) !== Boolean(table._locale)) {
30
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.`);
31
73
  }
32
74
  }
33
75
  };
34
76
 
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvdmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCbG9jayB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IEludmFsaWRDb25maWd1cmF0aW9uIH0gZnJvbSAncGF5bG9hZC9lcnJvcnMnXG5pbXBvcnQgeyBmbGF0dGVuVG9wTGV2ZWxGaWVsZHMgfSBmcm9tICdwYXlsb2FkL3V0aWxpdGllcydcblxuaW1wb3J0IHR5cGUgeyBHZW5lcmljVGFibGUgfSBmcm9tICcuLi90eXBlcydcblxudHlwZSBBcmdzID0ge1xuICBibG9jazogQmxvY2tcbiAgbG9jYWxpemVkOiBib29sZWFuXG4gIHJvb3RUYWJsZU5hbWU6IHN0cmluZ1xuICB0YWJsZTogR2VuZXJpY1RhYmxlXG59XG5cbmV4cG9ydCBjb25zdCB2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCA9ICh7XG4gIGJsb2NrLFxuICBsb2NhbGl6ZWQsXG4gIHJvb3RUYWJsZU5hbWUsXG4gIHRhYmxlLFxufTogQXJncyk6IHZvaWQgPT4ge1xuICBpZiAodGFibGUpIHtcbiAgICBjb25zdCBmaWVsZE5hbWVzID0gZmxhdHRlblRvcExldmVsRmllbGRzKGJsb2NrLmZpZWxkcykuZmxhdE1hcCgoZmllbGQpID0+IGZpZWxkLm5hbWUpXG5cbiAgICBPYmplY3Qua2V5cyh0YWJsZSkuZm9yRWFjaCgoZmllbGROYW1lKSA9PiB7XG4gICAgICBpZiAoIVsnX2xvY2FsZScsICdfb3JkZXInLCAnX3BhcmVudElEJywgJ19wYXRoJywgJ191dWlkJ10uaW5jbHVkZXMoZmllbGROYW1lKSkge1xuICAgICAgICBpZiAoZmllbGROYW1lcy5pbmRleE9mKGZpZWxkTmFtZSkgPT09IC0xKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICAgICAgYFRoZSB0YWJsZSAke3Jvb3RUYWJsZU5hbWV9IGhhcyBtdWx0aXBsZSBibG9ja3Mgd2l0aCBzbHVnICR7YmxvY2suc2x1Z30sIGJ1dCB0aGUgc2NoZW1hcyBkbyBub3QgbWF0Y2guIE9uZSBibG9jayBpbmNsdWRlcyB0aGUgZmllbGQgJHtmaWVsZE5hbWV9LCB3aGlsZSB0aGUgb3RoZXIgYmxvY2sgZG9lcyBub3QuYCxcbiAgICAgICAgICApXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KVxuXG4gICAgaWYgKEJvb2xlYW4obG9jYWxpemVkKSAhPT0gQm9vbGVhbih0YWJsZS5fbG9jYWxlKSkge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICBgVGhlIHRhYmxlICR7cm9vdFRhYmxlTmFtZX0gaGFzIG11bHRpcGxlIGJsb2NrcyB3aXRoIHNsdWcgJHtibG9jay5zbHVnfSwgYnV0IHRoZSBzY2hlbWFzIGRvIG5vdCBtYXRjaC4gT25lIGlzIGxvY2FsaXplZCwgYnV0IGFub3RoZXIgaXMgbm90LiBCbG9jayBzY2hlbWFzIG9mIHRoZSBzYW1lIG5hbWUgbXVzdCBtYXRjaCBleGFjdGx5LmAsXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsidmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwiLCJibG9jayIsImxvY2FsaXplZCIsInJvb3RUYWJsZU5hbWUiLCJ0YWJsZSIsImZpZWxkTmFtZXMiLCJmbGF0dGVuVG9wTGV2ZWxGaWVsZHMiLCJmaWVsZHMiLCJmbGF0TWFwIiwiZmllbGQiLCJuYW1lIiwiT2JqZWN0Iiwia2V5cyIsImZvckVhY2giLCJmaWVsZE5hbWUiLCJpbmNsdWRlcyIsImluZGV4T2YiLCJJbnZhbGlkQ29uZmlndXJhdGlvbiIsInNsdWciLCJCb29sZWFuIiwiX2xvY2FsZSJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFjYUE7OztlQUFBQTs7O3dCQVp3QjsyQkFDQztBQVcvQixNQUFNQSxtQ0FBbUMsQ0FBQyxFQUMvQ0MsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGFBQWEsRUFDYkMsS0FBSyxFQUNBO0lBQ0wsSUFBSUEsT0FBTztRQUNULE1BQU1DLGFBQWFDLElBQUFBLGdDQUFxQixFQUFDTCxNQUFNTSxNQUFNLEVBQUVDLE9BQU8sQ0FBQyxDQUFDQyxRQUFVQSxNQUFNQyxJQUFJO1FBRXBGQyxPQUFPQyxJQUFJLENBQUNSLE9BQU9TLE9BQU8sQ0FBQyxDQUFDQztZQUMxQixJQUFJLENBQUM7Z0JBQUM7Z0JBQVc7Z0JBQVU7Z0JBQWE7Z0JBQVM7YUFBUSxDQUFDQyxRQUFRLENBQUNELFlBQVk7Z0JBQzdFLElBQUlULFdBQVdXLE9BQU8sQ0FBQ0YsZUFBZSxDQUFDLEdBQUc7b0JBQ3hDLE1BQU0sSUFBSUcsNEJBQW9CLENBQzVCLENBQUMsVUFBVSxFQUFFZCxjQUFjLCtCQUErQixFQUFFRixNQUFNaUIsSUFBSSxDQUFDLDZEQUE2RCxFQUFFSixVQUFVLGlDQUFpQyxDQUFDO2dCQUV0TDtZQUNGO1FBQ0Y7UUFFQSxJQUFJSyxRQUFRakIsZUFBZWlCLFFBQVFmLE1BQU1nQixPQUFPLEdBQUc7WUFDakQsTUFBTSxJQUFJSCw0QkFBb0IsQ0FDNUIsQ0FBQyxVQUFVLEVBQUVkLGNBQWMsK0JBQStCLEVBQUVGLE1BQU1pQixJQUFJLENBQUMsd0hBQXdILENBQUM7UUFFcE07SUFDRjtBQUNGIn0=
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvdmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCbG9jaywgRmllbGQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgeyBJbnZhbGlkQ29uZmlndXJhdGlvbiB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgZmllbGRBZmZlY3RzRGF0YSwgZmllbGRIYXNTdWJGaWVsZHMsIHRhYkhhc05hbWUgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgdHlwZSB7IEdlbmVyaWNUYWJsZSB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGJsb2NrOiBCbG9ja1xuICBsb2NhbGl6ZWQ6IGJvb2xlYW5cbiAgcm9vdFRhYmxlTmFtZTogc3RyaW5nXG4gIHRhYmxlOiBHZW5lcmljVGFibGVcbn1cblxuY29uc3QgZ2V0RmxhdHRlbmVkRmllbGROYW1lcyA9IChmaWVsZHM6IEZpZWxkW10sIHByZWZpeDogc3RyaW5nID0gJycpOiBzdHJpbmdbXSA9PiB7XG4gIHJldHVybiBmaWVsZHMucmVkdWNlKChmaWVsZHNUb1VzZSwgZmllbGQpID0+IHtcbiAgICBsZXQgZmllbGRQcmVmaXggPSBwcmVmaXhcblxuICAgIGlmIChmaWVsZC50eXBlID09PSAnYmxvY2tzJykge1xuICAgICAgcmV0dXJuIGZpZWxkc1RvVXNlXG4gICAgfVxuXG4gICAgaWYgKGZpZWxkSGFzU3ViRmllbGRzKGZpZWxkKSkge1xuICAgICAgZmllbGRQcmVmaXggPSAnbmFtZScgaW4gZmllbGQgPyBgJHtwcmVmaXh9JHtmaWVsZC5uYW1lfS5gIDogcHJlZml4XG4gICAgICByZXR1cm4gWy4uLmZpZWxkc1RvVXNlLCAuLi5nZXRGbGF0dGVuZWRGaWVsZE5hbWVzKGZpZWxkLmZpZWxkcywgZmllbGRQcmVmaXgpXVxuICAgIH1cblxuICAgIGlmIChmaWVsZC50eXBlID09PSAndGFicycpIHtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIC4uLmZpZWxkc1RvVXNlLFxuICAgICAgICAuLi5maWVsZC50YWJzLnJlZHVjZSgodGFiRmllbGRzLCB0YWIpID0+IHtcbiAgICAgICAgICBmaWVsZFByZWZpeCA9ICduYW1lJyBpbiB0YWIgPyBgJHtwcmVmaXh9LiR7dGFiLm5hbWV9YCA6IHByZWZpeFxuICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICAuLi50YWJGaWVsZHMsXG4gICAgICAgICAgICAuLi4odGFiSGFzTmFtZSh0YWIpXG4gICAgICAgICAgICAgID8gW3sgLi4udGFiLCB0eXBlOiAndGFiJyB9XVxuICAgICAgICAgICAgICA6IGdldEZsYXR0ZW5lZEZpZWxkTmFtZXModGFiLmZpZWxkcywgZmllbGRQcmVmaXgpKSxcbiAgICAgICAgICBdXG4gICAgICAgIH0sIFtdKSxcbiAgICAgIF1cbiAgICB9XG5cbiAgICBpZiAoZmllbGRBZmZlY3RzRGF0YShmaWVsZCkpIHtcbiAgICAgIHJldHVybiBbLi4uZmllbGRzVG9Vc2UsIGAke2ZpZWxkUHJlZml4Py5yZXBsYWNlKCcuJywgJ18nKSB8fCAnJ30ke2ZpZWxkLm5hbWV9YF1cbiAgICB9XG5cbiAgICByZXR1cm4gZmllbGRzVG9Vc2VcbiAgfSwgW10pXG59XG5cbmV4cG9ydCBjb25zdCB2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCA9ICh7XG4gIGJsb2NrLFxuICBsb2NhbGl6ZWQsXG4gIHJvb3RUYWJsZU5hbWUsXG4gIHRhYmxlLFxufTogQXJncyk6IHZvaWQgPT4ge1xuICBpZiAodGFibGUpIHtcbiAgICBjb25zdCBmaWVsZE5hbWVzID0gZ2V0RmxhdHRlbmVkRmllbGROYW1lcyhibG9jay5maWVsZHMpXG5cbiAgICBjb25zdCBtaXNzaW5nRmllbGQgPVxuICAgICAgLy8gZW5zdXJlIGV2ZXJ5IGZpZWxkIGZyb20gdGhlIGNvbmZpZyBpcyBpbiB0aGUgbWF0Y2hpbmcgdGFibGVcbiAgICAgIGZpZWxkTmFtZXMuZmluZCgobmFtZSkgPT4gT2JqZWN0LmtleXModGFibGUpLmluZGV4T2YobmFtZSkgPT09IC0xKSB8fFxuICAgICAgLy8gZW5zdXJlIGV2ZXJ5IHRhYmxlIGNvbHVtbiBpcyBtYXRjaGVkIGZvciBldmVyeSBmaWVsZCBmcm9tIHRoZSBjb25maWdcbiAgICAgIE9iamVjdC5rZXlzKHRhYmxlKS5maW5kKChmaWVsZE5hbWUpID0+IHtcbiAgICAgICAgaWYgKCFbJ19sb2NhbGUnLCAnX29yZGVyJywgJ19wYXJlbnRJRCcsICdfcGF0aCcsICdfdXVpZCddLmluY2x1ZGVzKGZpZWxkTmFtZSkpIHtcbiAgICAgICAgICByZXR1cm4gZmllbGROYW1lcy5pbmRleE9mKGZpZWxkTmFtZSkgPT09IC0xXG4gICAgICAgIH1cbiAgICAgIH0pXG5cbiAgICBpZiAobWlzc2luZ0ZpZWxkKSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZENvbmZpZ3VyYXRpb24oXG4gICAgICAgIGBUaGUgdGFibGUgJHtyb290VGFibGVOYW1lfSBoYXMgbXVsdGlwbGUgYmxvY2tzIHdpdGggc2x1ZyAke2Jsb2NrLnNsdWd9LCBidXQgdGhlIHNjaGVtYXMgZG8gbm90IG1hdGNoLiBPbmUgYmxvY2sgaW5jbHVkZXMgdGhlIGZpZWxkICR7bWlzc2luZ0ZpZWxkfSwgd2hpbGUgdGhlIG90aGVyIGJsb2NrIGRvZXMgbm90LmAsXG4gICAgICApXG4gICAgfVxuXG4gICAgaWYgKEJvb2xlYW4obG9jYWxpemVkKSAhPT0gQm9vbGVhbih0YWJsZS5fbG9jYWxlKSkge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICBgVGhlIHRhYmxlICR7cm9vdFRhYmxlTmFtZX0gaGFzIG11bHRpcGxlIGJsb2NrcyB3aXRoIHNsdWcgJHtibG9jay5zbHVnfSwgYnV0IHRoZSBzY2hlbWFzIGRvIG5vdCBtYXRjaC4gT25lIGlzIGxvY2FsaXplZCwgYnV0IGFub3RoZXIgaXMgbm90LiBCbG9jayBzY2hlbWFzIG9mIHRoZSBzYW1lIG5hbWUgbXVzdCBtYXRjaCBleGFjdGx5LmAsXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsidmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwiLCJnZXRGbGF0dGVuZWRGaWVsZE5hbWVzIiwiZmllbGRzIiwicHJlZml4IiwicmVkdWNlIiwiZmllbGRzVG9Vc2UiLCJmaWVsZCIsImZpZWxkUHJlZml4IiwidHlwZSIsImZpZWxkSGFzU3ViRmllbGRzIiwibmFtZSIsInRhYnMiLCJ0YWJGaWVsZHMiLCJ0YWIiLCJ0YWJIYXNOYW1lIiwiZmllbGRBZmZlY3RzRGF0YSIsInJlcGxhY2UiLCJibG9jayIsImxvY2FsaXplZCIsInJvb3RUYWJsZU5hbWUiLCJ0YWJsZSIsImZpZWxkTmFtZXMiLCJtaXNzaW5nRmllbGQiLCJmaW5kIiwiT2JqZWN0Iiwia2V5cyIsImluZGV4T2YiLCJmaWVsZE5hbWUiLCJpbmNsdWRlcyIsIkludmFsaWRDb25maWd1cmF0aW9uIiwic2x1ZyIsIkJvb2xlYW4iLCJfbG9jYWxlIl0sIm1hcHBpbmdzIjoiOzs7OytCQWtEYUE7OztlQUFBQTs7O3dCQWhEd0I7dUJBQzJCO0FBV2hFLE1BQU1DLHlCQUF5QixDQUFDQyxRQUFpQkMsU0FBaUIsRUFBRTtJQUNsRSxPQUFPRCxPQUFPRSxNQUFNLENBQUMsQ0FBQ0MsYUFBYUM7UUFDakMsSUFBSUMsY0FBY0o7UUFFbEIsSUFBSUcsTUFBTUUsSUFBSSxLQUFLLFVBQVU7WUFDM0IsT0FBT0g7UUFDVDtRQUVBLElBQUlJLElBQUFBLHdCQUFpQixFQUFDSCxRQUFRO1lBQzVCQyxjQUFjLFVBQVVELFFBQVEsQ0FBQyxFQUFFSCxPQUFPLEVBQUVHLE1BQU1JLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBR1A7WUFDNUQsT0FBTzttQkFBSUU7bUJBQWdCSix1QkFBdUJLLE1BQU1KLE1BQU0sRUFBRUs7YUFBYTtRQUMvRTtRQUVBLElBQUlELE1BQU1FLElBQUksS0FBSyxRQUFRO1lBQ3pCLE9BQU87bUJBQ0ZIO21CQUNBQyxNQUFNSyxJQUFJLENBQUNQLE1BQU0sQ0FBQyxDQUFDUSxXQUFXQztvQkFDL0JOLGNBQWMsVUFBVU0sTUFBTSxDQUFDLEVBQUVWLE9BQU8sQ0FBQyxFQUFFVSxJQUFJSCxJQUFJLENBQUMsQ0FBQyxHQUFHUDtvQkFDeEQsT0FBTzsyQkFDRlM7MkJBQ0NFLElBQUFBLGlCQUFVLEVBQUNELE9BQ1g7NEJBQUM7Z0NBQUUsR0FBR0EsR0FBRztnQ0FBRUwsTUFBTTs0QkFBTTt5QkFBRSxHQUN6QlAsdUJBQXVCWSxJQUFJWCxNQUFNLEVBQUVLO3FCQUN4QztnQkFDSCxHQUFHLEVBQUU7YUFDTjtRQUNIO1FBRUEsSUFBSVEsSUFBQUEsdUJBQWdCLEVBQUNULFFBQVE7WUFDM0IsT0FBTzttQkFBSUQ7Z0JBQWEsQ0FBQyxFQUFFRSxhQUFhUyxRQUFRLEtBQUssUUFBUSxHQUFHLEVBQUVWLE1BQU1JLElBQUksQ0FBQyxDQUFDO2FBQUM7UUFDakY7UUFFQSxPQUFPTDtJQUNULEdBQUcsRUFBRTtBQUNQO0FBRU8sTUFBTUwsbUNBQW1DLENBQUMsRUFDL0NpQixLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsYUFBYSxFQUNiQyxLQUFLLEVBQ0E7SUFDTCxJQUFJQSxPQUFPO1FBQ1QsTUFBTUMsYUFBYXBCLHVCQUF1QmdCLE1BQU1mLE1BQU07UUFFdEQsTUFBTW9CLGVBQ0osOERBQThEO1FBQzlERCxXQUFXRSxJQUFJLENBQUMsQ0FBQ2IsT0FBU2MsT0FBT0MsSUFBSSxDQUFDTCxPQUFPTSxPQUFPLENBQUNoQixVQUFVLENBQUMsTUFDaEUsdUVBQXVFO1FBQ3ZFYyxPQUFPQyxJQUFJLENBQUNMLE9BQU9HLElBQUksQ0FBQyxDQUFDSTtZQUN2QixJQUFJLENBQUM7Z0JBQUM7Z0JBQVc7Z0JBQVU7Z0JBQWE7Z0JBQVM7YUFBUSxDQUFDQyxRQUFRLENBQUNELFlBQVk7Z0JBQzdFLE9BQU9OLFdBQVdLLE9BQU8sQ0FBQ0MsZUFBZSxDQUFDO1lBQzVDO1FBQ0Y7UUFFRixJQUFJTCxjQUFjO1lBQ2hCLE1BQU0sSUFBSU8sNEJBQW9CLENBQzVCLENBQUMsVUFBVSxFQUFFVixjQUFjLCtCQUErQixFQUFFRixNQUFNYSxJQUFJLENBQUMsNkRBQTZELEVBQUVSLGFBQWEsaUNBQWlDLENBQUM7UUFFekw7UUFFQSxJQUFJUyxRQUFRYixlQUFlYSxRQUFRWCxNQUFNWSxPQUFPLEdBQUc7WUFDakQsTUFBTSxJQUFJSCw0QkFBb0IsQ0FDNUIsQ0FBQyxVQUFVLEVBQUVWLGNBQWMsK0JBQStCLEVBQUVGLE1BQU1hLElBQUksQ0FBQyx3SEFBd0gsQ0FBQztRQUVwTTtJQUNGO0FBQ0YifQ==
@@ -0,0 +1,10 @@
1
+ import type { TextField } from 'payload/types';
2
+ type Args = {
3
+ field: TextField;
4
+ locale?: string;
5
+ textRows: Record<string, unknown>[];
6
+ ref: Record<string, unknown>;
7
+ };
8
+ export declare const transformHasManyText: ({ field, locale, textRows, ref }: Args) => void;
9
+ export {};
10
+ //# sourceMappingURL=hasManyText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasManyText.d.ts","sourceRoot":"","sources":["../../../src/transform/read/hasManyText.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAE9C,KAAK,IAAI,GAAG;IACV,KAAK,EAAE,SAAS,CAAA;IAChB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IACnC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC7B,CAAA;AAED,eAAO,MAAM,oBAAoB,qCAAsC,IAAI,SAQ1E,CAAA"}
@@ -0,0 +1,20 @@
1
+ /* eslint-disable no-param-reassign */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "transformHasManyText", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return transformHasManyText;
9
+ }
10
+ });
11
+ const transformHasManyText = ({ field, locale, textRows, ref })=>{
12
+ const result = textRows.map(({ text })=>text);
13
+ if (locale) {
14
+ ref[field.name][locale] = result;
15
+ } else {
16
+ ref[field.name] = result;
17
+ }
18
+ };
19
+
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2Zvcm0vcmVhZC9oYXNNYW55VGV4dC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuaW1wb3J0IHR5cGUgeyBUZXh0RmllbGQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGZpZWxkOiBUZXh0RmllbGRcbiAgbG9jYWxlPzogc3RyaW5nXG4gIHRleHRSb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdXG4gIHJlZjogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbn1cblxuZXhwb3J0IGNvbnN0IHRyYW5zZm9ybUhhc01hbnlUZXh0ID0gKHsgZmllbGQsIGxvY2FsZSwgdGV4dFJvd3MsIHJlZiB9OiBBcmdzKSA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IHRleHRSb3dzLm1hcCgoeyB0ZXh0IH0pID0+IHRleHQpXG5cbiAgaWYgKGxvY2FsZSkge1xuICAgIHJlZltmaWVsZC5uYW1lXVtsb2NhbGVdID0gcmVzdWx0XG4gIH0gZWxzZSB7XG4gICAgcmVmW2ZpZWxkLm5hbWVdID0gcmVzdWx0XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJ0cmFuc2Zvcm1IYXNNYW55VGV4dCIsImZpZWxkIiwibG9jYWxlIiwidGV4dFJvd3MiLCJyZWYiLCJyZXN1bHQiLCJtYXAiLCJ0ZXh0IiwibmFtZSJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQVV2QkE7OztlQUFBQTs7O0FBQU4sTUFBTUEsdUJBQXVCLENBQUMsRUFBRUMsS0FBSyxFQUFFQyxNQUFNLEVBQUVDLFFBQVEsRUFBRUMsR0FBRyxFQUFRO0lBQ3pFLE1BQU1DLFNBQVNGLFNBQVNHLEdBQUcsQ0FBQyxDQUFDLEVBQUVDLElBQUksRUFBRSxHQUFLQTtJQUUxQyxJQUFJTCxRQUFRO1FBQ1ZFLEdBQUcsQ0FBQ0gsTUFBTU8sSUFBSSxDQUFDLENBQUNOLE9BQU8sR0FBR0c7SUFDNUIsT0FBTztRQUNMRCxHQUFHLENBQUNILE1BQU1PLElBQUksQ0FBQyxHQUFHSDtJQUNwQjtBQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/transform/read/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAMtD,KAAK,aAAa,GAAG;IACnB,MAAM,EAAE,eAAe,CAAA;IACvB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC7B,cAAc,CAAC,EAAE,KAAK,GAAG,MAAM,CAAA;IAC/B,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,CAAA;AAID,eAAO,MAAM,SAAS,mDAAoD,aAAa,MAmCtF,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/transform/read/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAMtD,KAAK,aAAa,GAAG;IACnB,MAAM,EAAE,eAAe,CAAA;IACvB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC7B,cAAc,CAAC,EAAE,KAAK,GAAG,MAAM,CAAA;IAC/B,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,CAAA;AAID,eAAO,MAAM,SAAS,mDAAoD,aAAa,MA0CtF,CAAA"}
@@ -13,11 +13,16 @@ const _createRelationshipMap = require("../../utilities/createRelationshipMap");
13
13
  const _traverseFields = require("./traverseFields");
14
14
  const transform = ({ config, data, fields })=>{
15
15
  let relationships = {};
16
+ let texts = {};
16
17
  let numbers = {};
17
18
  if ('_rels' in data) {
18
19
  relationships = (0, _createRelationshipMap.createPathMap)(data._rels);
19
20
  delete data._rels;
20
21
  }
22
+ if ('_texts' in data) {
23
+ texts = (0, _createRelationshipMap.createPathMap)(data._texts);
24
+ delete data._texts;
25
+ }
21
26
  if ('_numbers' in data) {
22
27
  numbers = (0, _createRelationshipMap.createPathMap)(data._numbers);
23
28
  delete data._numbers;
@@ -33,6 +38,7 @@ const transform = ({ config, data, fields })=>{
33
38
  deletions,
34
39
  fieldPrefix: '',
35
40
  fields,
41
+ texts,
36
42
  numbers,
37
43
  path: '',
38
44
  relationships,
@@ -42,4 +48,4 @@ const transform = ({ config, data, fields })=>{
42
48
  return result;
43
49
  };
44
50
 
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2Zvcm0vcmVhZC9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb25maWcgfSBmcm9tICdwYXlsb2FkL2NvbmZpZydcbmltcG9ydCB0eXBlIHsgRmllbGQsIFR5cGVXaXRoSUQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgeyBjcmVhdGVCbG9ja3NNYXAgfSBmcm9tICcuLi8uLi91dGlsaXRpZXMvY3JlYXRlQmxvY2tzTWFwJ1xuaW1wb3J0IHsgY3JlYXRlUGF0aE1hcCB9IGZyb20gJy4uLy4uL3V0aWxpdGllcy9jcmVhdGVSZWxhdGlvbnNoaXBNYXAnXG5pbXBvcnQgeyB0cmF2ZXJzZUZpZWxkcyB9IGZyb20gJy4vdHJhdmVyc2VGaWVsZHMnXG5cbnR5cGUgVHJhbnNmb3JtQXJncyA9IHtcbiAgY29uZmlnOiBTYW5pdGl6ZWRDb25maWdcbiAgZGF0YTogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZmFsbGJhY2tMb2NhbGU/OiBmYWxzZSB8IHN0cmluZ1xuICBmaWVsZHM6IEZpZWxkW11cbiAgbG9jYWxlPzogc3RyaW5nXG59XG5cbi8vIFRoaXMgaXMgdGhlIGVudHJ5IHBvaW50IHRvIHRyYW5zZm9ybSBEcml6emxlIG91dHB1dCBkYXRhXG4vLyBpbnRvIHRoZSBzaGFwZSBQYXlsb2FkIGV4cGVjdHMgYmFzZWQgb24gZmllbGQgc2NoZW1hXG5leHBvcnQgY29uc3QgdHJhbnNmb3JtID0gPFQgZXh0ZW5kcyBUeXBlV2l0aElEPih7IGNvbmZpZywgZGF0YSwgZmllbGRzIH06IFRyYW5zZm9ybUFyZ3MpOiBUID0+IHtcbiAgbGV0IHJlbGF0aW9uc2hpcHM6IFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIHVua25vd24+W10+ID0ge31cbiAgbGV0IG51bWJlcnM6IFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIHVua25vd24+W10+ID0ge31cblxuICBpZiAoJ19yZWxzJyBpbiBkYXRhKSB7XG4gICAgcmVsYXRpb25zaGlwcyA9IGNyZWF0ZVBhdGhNYXAoZGF0YS5fcmVscylcbiAgICBkZWxldGUgZGF0YS5fcmVsc1xuICB9XG5cbiAgaWYgKCdfbnVtYmVycycgaW4gZGF0YSkge1xuICAgIG51bWJlcnMgPSBjcmVhdGVQYXRoTWFwKGRhdGEuX251bWJlcnMpXG4gICAgZGVsZXRlIGRhdGEuX251bWJlcnNcbiAgfVxuXG4gIGNvbnN0IGJsb2NrcyA9IGNyZWF0ZUJsb2Nrc01hcChkYXRhKVxuICBjb25zdCBkZWxldGlvbnMgPSBbXVxuXG4gIGNvbnN0IHJlc3VsdCA9IHRyYXZlcnNlRmllbGRzPFQ+KHtcbiAgICBibG9ja3MsXG4gICAgY29uZmlnLFxuICAgIGRhdGFSZWY6IHtcbiAgICAgIGlkOiBkYXRhLmlkLFxuICAgIH0sXG4gICAgZGVsZXRpb25zLFxuICAgIGZpZWxkUHJlZml4OiAnJyxcbiAgICBmaWVsZHMsXG4gICAgbnVtYmVycyxcbiAgICBwYXRoOiAnJyxcbiAgICByZWxhdGlvbnNoaXBzLFxuICAgIHRhYmxlOiBkYXRhLFxuICB9KVxuXG4gIGRlbGV0aW9ucy5mb3JFYWNoKChkZWxldGlvbikgPT4gZGVsZXRpb24oKSlcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsidHJhbnNmb3JtIiwiY29uZmlnIiwiZGF0YSIsImZpZWxkcyIsInJlbGF0aW9uc2hpcHMiLCJudW1iZXJzIiwiY3JlYXRlUGF0aE1hcCIsIl9yZWxzIiwiX251bWJlcnMiLCJibG9ja3MiLCJjcmVhdGVCbG9ja3NNYXAiLCJkZWxldGlvbnMiLCJyZXN1bHQiLCJ0cmF2ZXJzZUZpZWxkcyIsImRhdGFSZWYiLCJpZCIsImZpZWxkUHJlZml4IiwicGF0aCIsInRhYmxlIiwiZm9yRWFjaCIsImRlbGV0aW9uIl0sIm1hcHBpbmdzIjoiQUFBQSxvQ0FBb0M7Ozs7K0JBa0J2QkE7OztlQUFBQTs7O2lDQWRtQjt1Q0FDRjtnQ0FDQztBQVl4QixNQUFNQSxZQUFZLENBQXVCLEVBQUVDLE1BQU0sRUFBRUMsSUFBSSxFQUFFQyxNQUFNLEVBQWlCO0lBQ3JGLElBQUlDLGdCQUEyRCxDQUFDO0lBQ2hFLElBQUlDLFVBQXFELENBQUM7SUFFMUQsSUFBSSxXQUFXSCxNQUFNO1FBQ25CRSxnQkFBZ0JFLElBQUFBLG9DQUFhLEVBQUNKLEtBQUtLLEtBQUs7UUFDeEMsT0FBT0wsS0FBS0ssS0FBSztJQUNuQjtJQUVBLElBQUksY0FBY0wsTUFBTTtRQUN0QkcsVUFBVUMsSUFBQUEsb0NBQWEsRUFBQ0osS0FBS00sUUFBUTtRQUNyQyxPQUFPTixLQUFLTSxRQUFRO0lBQ3RCO0lBRUEsTUFBTUMsU0FBU0MsSUFBQUEsZ0NBQWUsRUFBQ1I7SUFDL0IsTUFBTVMsWUFBWSxFQUFFO0lBRXBCLE1BQU1DLFNBQVNDLElBQUFBLDhCQUFjLEVBQUk7UUFDL0JKO1FBQ0FSO1FBQ0FhLFNBQVM7WUFDUEMsSUFBSWIsS0FBS2EsRUFBRTtRQUNiO1FBQ0FKO1FBQ0FLLGFBQWE7UUFDYmI7UUFDQUU7UUFDQVksTUFBTTtRQUNOYjtRQUNBYyxPQUFPaEI7SUFDVDtJQUVBUyxVQUFVUSxPQUFPLENBQUMsQ0FBQ0MsV0FBYUE7SUFFaEMsT0FBT1I7QUFDVCJ9
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2Zvcm0vcmVhZC9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb25maWcgfSBmcm9tICdwYXlsb2FkL2NvbmZpZydcbmltcG9ydCB0eXBlIHsgRmllbGQsIFR5cGVXaXRoSUQgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5pbXBvcnQgeyBjcmVhdGVCbG9ja3NNYXAgfSBmcm9tICcuLi8uLi91dGlsaXRpZXMvY3JlYXRlQmxvY2tzTWFwJ1xuaW1wb3J0IHsgY3JlYXRlUGF0aE1hcCB9IGZyb20gJy4uLy4uL3V0aWxpdGllcy9jcmVhdGVSZWxhdGlvbnNoaXBNYXAnXG5pbXBvcnQgeyB0cmF2ZXJzZUZpZWxkcyB9IGZyb20gJy4vdHJhdmVyc2VGaWVsZHMnXG5cbnR5cGUgVHJhbnNmb3JtQXJncyA9IHtcbiAgY29uZmlnOiBTYW5pdGl6ZWRDb25maWdcbiAgZGF0YTogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZmFsbGJhY2tMb2NhbGU/OiBmYWxzZSB8IHN0cmluZ1xuICBmaWVsZHM6IEZpZWxkW11cbiAgbG9jYWxlPzogc3RyaW5nXG59XG5cbi8vIFRoaXMgaXMgdGhlIGVudHJ5IHBvaW50IHRvIHRyYW5zZm9ybSBEcml6emxlIG91dHB1dCBkYXRhXG4vLyBpbnRvIHRoZSBzaGFwZSBQYXlsb2FkIGV4cGVjdHMgYmFzZWQgb24gZmllbGQgc2NoZW1hXG5leHBvcnQgY29uc3QgdHJhbnNmb3JtID0gPFQgZXh0ZW5kcyBUeXBlV2l0aElEPih7IGNvbmZpZywgZGF0YSwgZmllbGRzIH06IFRyYW5zZm9ybUFyZ3MpOiBUID0+IHtcbiAgbGV0IHJlbGF0aW9uc2hpcHM6IFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIHVua25vd24+W10+ID0ge31cbiAgbGV0IHRleHRzOiBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdPiA9IHt9XG4gIGxldCBudW1iZXJzOiBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdPiA9IHt9XG5cbiAgaWYgKCdfcmVscycgaW4gZGF0YSkge1xuICAgIHJlbGF0aW9uc2hpcHMgPSBjcmVhdGVQYXRoTWFwKGRhdGEuX3JlbHMpXG4gICAgZGVsZXRlIGRhdGEuX3JlbHNcbiAgfVxuXG4gIGlmICgnX3RleHRzJyBpbiBkYXRhKSB7XG4gICAgdGV4dHMgPSBjcmVhdGVQYXRoTWFwKGRhdGEuX3RleHRzKVxuICAgIGRlbGV0ZSBkYXRhLl90ZXh0c1xuICB9XG5cbiAgaWYgKCdfbnVtYmVycycgaW4gZGF0YSkge1xuICAgIG51bWJlcnMgPSBjcmVhdGVQYXRoTWFwKGRhdGEuX251bWJlcnMpXG4gICAgZGVsZXRlIGRhdGEuX251bWJlcnNcbiAgfVxuXG4gIGNvbnN0IGJsb2NrcyA9IGNyZWF0ZUJsb2Nrc01hcChkYXRhKVxuICBjb25zdCBkZWxldGlvbnMgPSBbXVxuXG4gIGNvbnN0IHJlc3VsdCA9IHRyYXZlcnNlRmllbGRzPFQ+KHtcbiAgICBibG9ja3MsXG4gICAgY29uZmlnLFxuICAgIGRhdGFSZWY6IHtcbiAgICAgIGlkOiBkYXRhLmlkLFxuICAgIH0sXG4gICAgZGVsZXRpb25zLFxuICAgIGZpZWxkUHJlZml4OiAnJyxcbiAgICBmaWVsZHMsXG4gICAgdGV4dHMsXG4gICAgbnVtYmVycyxcbiAgICBwYXRoOiAnJyxcbiAgICByZWxhdGlvbnNoaXBzLFxuICAgIHRhYmxlOiBkYXRhLFxuICB9KVxuXG4gIGRlbGV0aW9ucy5mb3JFYWNoKChkZWxldGlvbikgPT4gZGVsZXRpb24oKSlcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsidHJhbnNmb3JtIiwiY29uZmlnIiwiZGF0YSIsImZpZWxkcyIsInJlbGF0aW9uc2hpcHMiLCJ0ZXh0cyIsIm51bWJlcnMiLCJjcmVhdGVQYXRoTWFwIiwiX3JlbHMiLCJfdGV4dHMiLCJfbnVtYmVycyIsImJsb2NrcyIsImNyZWF0ZUJsb2Nrc01hcCIsImRlbGV0aW9ucyIsInJlc3VsdCIsInRyYXZlcnNlRmllbGRzIiwiZGF0YVJlZiIsImlkIiwiZmllbGRQcmVmaXgiLCJwYXRoIiwidGFibGUiLCJmb3JFYWNoIiwiZGVsZXRpb24iXSwibWFwcGluZ3MiOiJBQUFBLG9DQUFvQzs7OzsrQkFrQnZCQTs7O2VBQUFBOzs7aUNBZG1CO3VDQUNGO2dDQUNDO0FBWXhCLE1BQU1BLFlBQVksQ0FBdUIsRUFBRUMsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLE1BQU0sRUFBaUI7SUFDckYsSUFBSUMsZ0JBQTJELENBQUM7SUFDaEUsSUFBSUMsUUFBbUQsQ0FBQztJQUN4RCxJQUFJQyxVQUFxRCxDQUFDO0lBRTFELElBQUksV0FBV0osTUFBTTtRQUNuQkUsZ0JBQWdCRyxJQUFBQSxvQ0FBYSxFQUFDTCxLQUFLTSxLQUFLO1FBQ3hDLE9BQU9OLEtBQUtNLEtBQUs7SUFDbkI7SUFFQSxJQUFJLFlBQVlOLE1BQU07UUFDcEJHLFFBQVFFLElBQUFBLG9DQUFhLEVBQUNMLEtBQUtPLE1BQU07UUFDakMsT0FBT1AsS0FBS08sTUFBTTtJQUNwQjtJQUVBLElBQUksY0FBY1AsTUFBTTtRQUN0QkksVUFBVUMsSUFBQUEsb0NBQWEsRUFBQ0wsS0FBS1EsUUFBUTtRQUNyQyxPQUFPUixLQUFLUSxRQUFRO0lBQ3RCO0lBRUEsTUFBTUMsU0FBU0MsSUFBQUEsZ0NBQWUsRUFBQ1Y7SUFDL0IsTUFBTVcsWUFBWSxFQUFFO0lBRXBCLE1BQU1DLFNBQVNDLElBQUFBLDhCQUFjLEVBQUk7UUFDL0JKO1FBQ0FWO1FBQ0FlLFNBQVM7WUFDUEMsSUFBSWYsS0FBS2UsRUFBRTtRQUNiO1FBQ0FKO1FBQ0FLLGFBQWE7UUFDYmY7UUFDQUU7UUFDQUM7UUFDQWEsTUFBTTtRQUNOZjtRQUNBZ0IsT0FBT2xCO0lBQ1Q7SUFFQVcsVUFBVVEsT0FBTyxDQUFDLENBQUNDLFdBQWFBO0lBRWhDLE9BQU9SO0FBQ1QifQ==
@@ -26,6 +26,10 @@ 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>[]>;
29
33
  /**
30
34
  * All hasMany number fields, as returned by Drizzle, keyed on an object by field path
31
35
  */
@@ -43,6 +47,6 @@ type TraverseFieldsArgs = {
43
47
  */
44
48
  table: Record<string, unknown>;
45
49
  };
46
- export declare const traverseFields: <T extends Record<string, unknown>>({ blocks, config, dataRef, deletions, fieldPrefix, fields, numbers, path, relationships, table, }: TraverseFieldsArgs) => T;
50
+ export declare const traverseFields: <T extends Record<string, unknown>>({ blocks, config, dataRef, deletions, fieldPrefix, fields, texts, numbers, path, relationships, table, }: TraverseFieldsArgs) => T;
47
51
  export {};
48
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;AAKhE,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;CAC/B,CAAA;AAID,eAAO,MAAM,cAAc,yIAWxB,kBAAkB,MAyYpB,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,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"}