@payloadcms/plugin-import-export 3.71.0-internal.ef75fa0 → 3.71.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (322) hide show
  1. package/dist/components/CollectionField/index.d.ts.map +1 -1
  2. package/dist/components/CollectionField/index.js +8 -3
  3. package/dist/components/CollectionField/index.js.map +1 -1
  4. package/dist/components/ExportListMenuItem/index.d.ts +0 -1
  5. package/dist/components/ExportListMenuItem/index.d.ts.map +1 -1
  6. package/dist/components/ExportListMenuItem/index.js +0 -1
  7. package/dist/components/ExportListMenuItem/index.js.map +1 -1
  8. package/dist/components/ExportPreview/index.d.ts +4 -0
  9. package/dist/components/ExportPreview/index.d.ts.map +1 -0
  10. package/dist/components/ExportPreview/index.js +252 -0
  11. package/dist/components/ExportPreview/index.js.map +1 -0
  12. package/dist/components/ExportPreview/index.scss +36 -0
  13. package/dist/components/ImportCollectionField/index.d.ts +3 -0
  14. package/dist/components/ImportCollectionField/index.d.ts.map +1 -0
  15. package/dist/components/ImportCollectionField/index.js +17 -0
  16. package/dist/components/ImportCollectionField/index.js.map +1 -0
  17. package/dist/components/ImportListMenuItem/index.d.ts +6 -0
  18. package/dist/components/ImportListMenuItem/index.d.ts.map +1 -0
  19. package/dist/components/ImportListMenuItem/index.js +48 -0
  20. package/dist/components/ImportListMenuItem/index.js.map +1 -0
  21. package/dist/components/ImportPreview/index.d.ts +4 -0
  22. package/dist/components/ImportPreview/index.d.ts.map +1 -0
  23. package/dist/components/ImportPreview/index.js +624 -0
  24. package/dist/components/ImportPreview/index.js.map +1 -0
  25. package/dist/components/ImportPreview/index.scss +41 -0
  26. package/dist/components/ImportSaveButton/index.d.ts +2 -0
  27. package/dist/components/ImportSaveButton/index.d.ts.map +1 -0
  28. package/dist/components/ImportSaveButton/index.js +18 -0
  29. package/dist/components/ImportSaveButton/index.js.map +1 -0
  30. package/dist/components/Page/index.scss +4 -2
  31. package/dist/constants.d.ts +21 -0
  32. package/dist/constants.d.ts.map +1 -0
  33. package/dist/constants.js +21 -0
  34. package/dist/constants.js.map +1 -0
  35. package/dist/export/batchProcessor.d.ts +107 -0
  36. package/dist/export/batchProcessor.d.ts.map +1 -0
  37. package/dist/export/batchProcessor.js +187 -0
  38. package/dist/export/batchProcessor.js.map +1 -0
  39. package/dist/export/createExport.d.ts +9 -4
  40. package/dist/export/createExport.d.ts.map +1 -1
  41. package/dist/export/createExport.js +163 -111
  42. package/dist/export/createExport.js.map +1 -1
  43. package/dist/export/getCreateExportCollectionTask.d.ts +1 -2
  44. package/dist/export/getCreateExportCollectionTask.d.ts.map +1 -1
  45. package/dist/export/getCreateExportCollectionTask.js +10 -18
  46. package/dist/export/getCreateExportCollectionTask.js.map +1 -1
  47. package/dist/export/getExportCollection.d.ts +8 -0
  48. package/dist/export/getExportCollection.d.ts.map +1 -0
  49. package/dist/export/getExportCollection.js +100 -0
  50. package/dist/export/getExportCollection.js.map +1 -0
  51. package/dist/export/getFields.d.ts +8 -2
  52. package/dist/export/getFields.d.ts.map +1 -1
  53. package/dist/export/getFields.js +7 -9
  54. package/dist/export/getFields.js.map +1 -1
  55. package/dist/export/handleDownload.d.ts +3 -0
  56. package/dist/export/handleDownload.d.ts.map +1 -0
  57. package/dist/export/{download.js → handleDownload.js} +7 -6
  58. package/dist/export/handleDownload.js.map +1 -0
  59. package/dist/export/handlePreview.d.ts +3 -0
  60. package/dist/export/handlePreview.d.ts.map +1 -0
  61. package/dist/export/handlePreview.js +163 -0
  62. package/dist/export/handlePreview.js.map +1 -0
  63. package/dist/exports/rsc.d.ts +5 -1
  64. package/dist/exports/rsc.d.ts.map +1 -1
  65. package/dist/exports/rsc.js +5 -1
  66. package/dist/exports/rsc.js.map +1 -1
  67. package/dist/import/batchProcessor.d.ts +46 -0
  68. package/dist/import/batchProcessor.d.ts.map +1 -0
  69. package/dist/import/batchProcessor.js +529 -0
  70. package/dist/import/batchProcessor.js.map +1 -0
  71. package/dist/import/createImport.d.ts +45 -0
  72. package/dist/import/createImport.d.ts.map +1 -0
  73. package/dist/import/createImport.js +175 -0
  74. package/dist/import/createImport.js.map +1 -0
  75. package/dist/import/getCreateImportCollectionTask.d.ts +13 -0
  76. package/dist/import/getCreateImportCollectionTask.d.ts.map +1 -0
  77. package/dist/import/getCreateImportCollectionTask.js +81 -0
  78. package/dist/import/getCreateImportCollectionTask.js.map +1 -0
  79. package/dist/import/getFields.d.ts +7 -0
  80. package/dist/import/getFields.d.ts.map +1 -0
  81. package/dist/import/getFields.js +150 -0
  82. package/dist/import/getFields.js.map +1 -0
  83. package/dist/import/getImportCollection.d.ts +8 -0
  84. package/dist/import/getImportCollection.d.ts.map +1 -0
  85. package/dist/import/getImportCollection.js +258 -0
  86. package/dist/import/getImportCollection.js.map +1 -0
  87. package/dist/import/handlePreview.d.ts +3 -0
  88. package/dist/import/handlePreview.d.ts.map +1 -0
  89. package/dist/import/handlePreview.js +94 -0
  90. package/dist/import/handlePreview.js.map +1 -0
  91. package/dist/index.d.ts +3 -2
  92. package/dist/index.d.ts.map +1 -1
  93. package/dist/index.js +68 -110
  94. package/dist/index.js.map +1 -1
  95. package/dist/translations/languages/ar.d.ts.map +1 -1
  96. package/dist/translations/languages/ar.js +21 -1
  97. package/dist/translations/languages/ar.js.map +1 -1
  98. package/dist/translations/languages/az.d.ts.map +1 -1
  99. package/dist/translations/languages/az.js +21 -1
  100. package/dist/translations/languages/az.js.map +1 -1
  101. package/dist/translations/languages/bg.d.ts.map +1 -1
  102. package/dist/translations/languages/bg.js +21 -1
  103. package/dist/translations/languages/bg.js.map +1 -1
  104. package/dist/translations/languages/bnBd.d.ts +4 -0
  105. package/dist/translations/languages/bnBd.d.ts.map +1 -0
  106. package/dist/translations/languages/bnBd.js +48 -0
  107. package/dist/translations/languages/bnBd.js.map +1 -0
  108. package/dist/translations/languages/bnIn.d.ts +4 -0
  109. package/dist/translations/languages/bnIn.d.ts.map +1 -0
  110. package/dist/translations/languages/bnIn.js +48 -0
  111. package/dist/translations/languages/bnIn.js.map +1 -0
  112. package/dist/translations/languages/ca.d.ts.map +1 -1
  113. package/dist/translations/languages/ca.js +21 -1
  114. package/dist/translations/languages/ca.js.map +1 -1
  115. package/dist/translations/languages/cs.d.ts.map +1 -1
  116. package/dist/translations/languages/cs.js +21 -1
  117. package/dist/translations/languages/cs.js.map +1 -1
  118. package/dist/translations/languages/da.d.ts.map +1 -1
  119. package/dist/translations/languages/da.js +21 -1
  120. package/dist/translations/languages/da.js.map +1 -1
  121. package/dist/translations/languages/de.d.ts.map +1 -1
  122. package/dist/translations/languages/de.js +21 -1
  123. package/dist/translations/languages/de.js.map +1 -1
  124. package/dist/translations/languages/en.d.ts +20 -0
  125. package/dist/translations/languages/en.d.ts.map +1 -1
  126. package/dist/translations/languages/en.js +21 -1
  127. package/dist/translations/languages/en.js.map +1 -1
  128. package/dist/translations/languages/es.d.ts.map +1 -1
  129. package/dist/translations/languages/es.js +21 -1
  130. package/dist/translations/languages/es.js.map +1 -1
  131. package/dist/translations/languages/et.d.ts.map +1 -1
  132. package/dist/translations/languages/et.js +21 -1
  133. package/dist/translations/languages/et.js.map +1 -1
  134. package/dist/translations/languages/fa.d.ts.map +1 -1
  135. package/dist/translations/languages/fa.js +21 -1
  136. package/dist/translations/languages/fa.js.map +1 -1
  137. package/dist/translations/languages/fr.d.ts.map +1 -1
  138. package/dist/translations/languages/fr.js +21 -1
  139. package/dist/translations/languages/fr.js.map +1 -1
  140. package/dist/translations/languages/he.d.ts.map +1 -1
  141. package/dist/translations/languages/he.js +21 -1
  142. package/dist/translations/languages/he.js.map +1 -1
  143. package/dist/translations/languages/hr.d.ts.map +1 -1
  144. package/dist/translations/languages/hr.js +21 -1
  145. package/dist/translations/languages/hr.js.map +1 -1
  146. package/dist/translations/languages/hu.d.ts.map +1 -1
  147. package/dist/translations/languages/hu.js +21 -1
  148. package/dist/translations/languages/hu.js.map +1 -1
  149. package/dist/translations/languages/hy.d.ts.map +1 -1
  150. package/dist/translations/languages/hy.js +21 -1
  151. package/dist/translations/languages/hy.js.map +1 -1
  152. package/dist/translations/languages/id.d.ts +4 -0
  153. package/dist/translations/languages/id.d.ts.map +1 -0
  154. package/dist/translations/languages/id.js +48 -0
  155. package/dist/translations/languages/id.js.map +1 -0
  156. package/dist/translations/languages/is.d.ts.map +1 -1
  157. package/dist/translations/languages/is.js +21 -1
  158. package/dist/translations/languages/is.js.map +1 -1
  159. package/dist/translations/languages/it.d.ts.map +1 -1
  160. package/dist/translations/languages/it.js +21 -1
  161. package/dist/translations/languages/it.js.map +1 -1
  162. package/dist/translations/languages/ja.d.ts.map +1 -1
  163. package/dist/translations/languages/ja.js +21 -1
  164. package/dist/translations/languages/ja.js.map +1 -1
  165. package/dist/translations/languages/ko.d.ts.map +1 -1
  166. package/dist/translations/languages/ko.js +21 -1
  167. package/dist/translations/languages/ko.js.map +1 -1
  168. package/dist/translations/languages/lt.d.ts.map +1 -1
  169. package/dist/translations/languages/lt.js +21 -1
  170. package/dist/translations/languages/lt.js.map +1 -1
  171. package/dist/translations/languages/lv.d.ts.map +1 -1
  172. package/dist/translations/languages/lv.js +26 -6
  173. package/dist/translations/languages/lv.js.map +1 -1
  174. package/dist/translations/languages/my.d.ts.map +1 -1
  175. package/dist/translations/languages/my.js +21 -1
  176. package/dist/translations/languages/my.js.map +1 -1
  177. package/dist/translations/languages/nb.d.ts.map +1 -1
  178. package/dist/translations/languages/nb.js +21 -1
  179. package/dist/translations/languages/nb.js.map +1 -1
  180. package/dist/translations/languages/nl.d.ts.map +1 -1
  181. package/dist/translations/languages/nl.js +21 -1
  182. package/dist/translations/languages/nl.js.map +1 -1
  183. package/dist/translations/languages/pl.d.ts.map +1 -1
  184. package/dist/translations/languages/pl.js +21 -1
  185. package/dist/translations/languages/pl.js.map +1 -1
  186. package/dist/translations/languages/pt.d.ts.map +1 -1
  187. package/dist/translations/languages/pt.js +21 -1
  188. package/dist/translations/languages/pt.js.map +1 -1
  189. package/dist/translations/languages/ro.d.ts.map +1 -1
  190. package/dist/translations/languages/ro.js +21 -1
  191. package/dist/translations/languages/ro.js.map +1 -1
  192. package/dist/translations/languages/rs.d.ts.map +1 -1
  193. package/dist/translations/languages/rs.js +21 -1
  194. package/dist/translations/languages/rs.js.map +1 -1
  195. package/dist/translations/languages/rsLatin.d.ts.map +1 -1
  196. package/dist/translations/languages/rsLatin.js +21 -1
  197. package/dist/translations/languages/rsLatin.js.map +1 -1
  198. package/dist/translations/languages/ru.d.ts.map +1 -1
  199. package/dist/translations/languages/ru.js +21 -1
  200. package/dist/translations/languages/ru.js.map +1 -1
  201. package/dist/translations/languages/sk.d.ts.map +1 -1
  202. package/dist/translations/languages/sk.js +21 -1
  203. package/dist/translations/languages/sk.js.map +1 -1
  204. package/dist/translations/languages/sl.d.ts.map +1 -1
  205. package/dist/translations/languages/sl.js +21 -1
  206. package/dist/translations/languages/sl.js.map +1 -1
  207. package/dist/translations/languages/sv.d.ts.map +1 -1
  208. package/dist/translations/languages/sv.js +21 -1
  209. package/dist/translations/languages/sv.js.map +1 -1
  210. package/dist/translations/languages/ta.d.ts.map +1 -1
  211. package/dist/translations/languages/ta.js +21 -1
  212. package/dist/translations/languages/ta.js.map +1 -1
  213. package/dist/translations/languages/th.d.ts.map +1 -1
  214. package/dist/translations/languages/th.js +21 -1
  215. package/dist/translations/languages/th.js.map +1 -1
  216. package/dist/translations/languages/tr.d.ts.map +1 -1
  217. package/dist/translations/languages/tr.js +21 -1
  218. package/dist/translations/languages/tr.js.map +1 -1
  219. package/dist/translations/languages/uk.d.ts.map +1 -1
  220. package/dist/translations/languages/uk.js +21 -1
  221. package/dist/translations/languages/uk.js.map +1 -1
  222. package/dist/translations/languages/vi.d.ts.map +1 -1
  223. package/dist/translations/languages/vi.js +21 -1
  224. package/dist/translations/languages/vi.js.map +1 -1
  225. package/dist/translations/languages/zh.d.ts.map +1 -1
  226. package/dist/translations/languages/zh.js +21 -1
  227. package/dist/translations/languages/zh.js.map +1 -1
  228. package/dist/translations/languages/zhTw.d.ts.map +1 -1
  229. package/dist/translations/languages/zhTw.js +21 -1
  230. package/dist/translations/languages/zhTw.js.map +1 -1
  231. package/dist/translations/types.d.ts +13 -0
  232. package/dist/translations/types.d.ts.map +1 -1
  233. package/dist/translations/types.js.map +1 -1
  234. package/dist/types.d.ts +166 -22
  235. package/dist/types.d.ts.map +1 -1
  236. package/dist/types.js +1 -1
  237. package/dist/types.js.map +1 -1
  238. package/dist/utilities/flattenObject.d.ts.map +1 -0
  239. package/dist/{export → utilities}/flattenObject.js +13 -6
  240. package/dist/utilities/flattenObject.js.map +1 -0
  241. package/dist/utilities/getExportFieldFunctions.d.ts +12 -0
  242. package/dist/utilities/getExportFieldFunctions.d.ts.map +1 -0
  243. package/dist/{export/getCustomFieldFunctions.js → utilities/getExportFieldFunctions.js} +18 -2
  244. package/dist/utilities/getExportFieldFunctions.js.map +1 -0
  245. package/dist/utilities/getFilename.d.ts +6 -0
  246. package/dist/utilities/getFilename.d.ts.map +1 -0
  247. package/dist/{export → utilities}/getFilename.js +4 -1
  248. package/dist/utilities/getFilename.js.map +1 -0
  249. package/dist/utilities/getFlattenedFieldKeys.d.ts +12 -1
  250. package/dist/utilities/getFlattenedFieldKeys.d.ts.map +1 -1
  251. package/dist/utilities/getFlattenedFieldKeys.js +35 -10
  252. package/dist/utilities/getFlattenedFieldKeys.js.map +1 -1
  253. package/dist/utilities/getImportFieldFunctions.d.ts +12 -0
  254. package/dist/utilities/getImportFieldFunctions.d.ts.map +1 -0
  255. package/dist/utilities/getImportFieldFunctions.js +130 -0
  256. package/dist/utilities/getImportFieldFunctions.js.map +1 -0
  257. package/dist/utilities/getPluginCollections.d.ts +39 -0
  258. package/dist/utilities/getPluginCollections.d.ts.map +1 -0
  259. package/dist/utilities/getPluginCollections.js +102 -0
  260. package/dist/utilities/getPluginCollections.js.map +1 -0
  261. package/dist/utilities/getSchemaColumns.d.ts +43 -0
  262. package/dist/utilities/getSchemaColumns.d.ts.map +1 -0
  263. package/dist/utilities/getSchemaColumns.js +163 -0
  264. package/dist/utilities/getSchemaColumns.js.map +1 -0
  265. package/dist/utilities/getSelect.d.ts +11 -0
  266. package/dist/utilities/getSelect.d.ts.map +1 -0
  267. package/dist/{export → utilities}/getSelect.js +6 -2
  268. package/dist/utilities/getSelect.js.map +1 -0
  269. package/dist/utilities/parseCSV.d.ts +11 -0
  270. package/dist/utilities/parseCSV.d.ts.map +1 -0
  271. package/dist/utilities/parseCSV.js +67 -0
  272. package/dist/utilities/parseCSV.js.map +1 -0
  273. package/dist/utilities/parseCSV.spec.js +169 -0
  274. package/dist/utilities/parseCSV.spec.js.map +1 -0
  275. package/dist/utilities/parseJSON.d.ts +11 -0
  276. package/dist/utilities/parseJSON.d.ts.map +1 -0
  277. package/dist/utilities/parseJSON.js +25 -0
  278. package/dist/utilities/parseJSON.js.map +1 -0
  279. package/dist/utilities/processRichTextField.d.ts +6 -0
  280. package/dist/utilities/processRichTextField.d.ts.map +1 -0
  281. package/dist/utilities/processRichTextField.js +45 -0
  282. package/dist/utilities/processRichTextField.js.map +1 -0
  283. package/dist/utilities/unflattenObject.d.ts +11 -0
  284. package/dist/utilities/unflattenObject.d.ts.map +1 -0
  285. package/dist/utilities/unflattenObject.js +431 -0
  286. package/dist/utilities/unflattenObject.js.map +1 -0
  287. package/dist/utilities/unflattenObject.spec.js +680 -0
  288. package/dist/utilities/unflattenObject.spec.js.map +1 -0
  289. package/dist/utilities/useBatchProcessor.d.ts +103 -0
  290. package/dist/utilities/useBatchProcessor.d.ts.map +1 -0
  291. package/dist/utilities/useBatchProcessor.js +88 -0
  292. package/dist/utilities/useBatchProcessor.js.map +1 -0
  293. package/dist/utilities/validateLimitValue.d.ts +1 -1
  294. package/dist/utilities/validateLimitValue.d.ts.map +1 -1
  295. package/dist/utilities/validateLimitValue.js +1 -4
  296. package/dist/utilities/validateLimitValue.js.map +1 -1
  297. package/package.json +9 -9
  298. package/dist/components/ExportListMenuItem/index.scss +0 -52
  299. package/dist/components/Preview/index.d.ts +0 -4
  300. package/dist/components/Preview/index.d.ts.map +0 -1
  301. package/dist/components/Preview/index.js +0 -180
  302. package/dist/components/Preview/index.js.map +0 -1
  303. package/dist/components/Preview/index.scss +0 -8
  304. package/dist/export/download.d.ts +0 -3
  305. package/dist/export/download.d.ts.map +0 -1
  306. package/dist/export/download.js.map +0 -1
  307. package/dist/export/flattenObject.d.ts.map +0 -1
  308. package/dist/export/flattenObject.js.map +0 -1
  309. package/dist/export/getCustomFieldFunctions.d.ts +0 -8
  310. package/dist/export/getCustomFieldFunctions.d.ts.map +0 -1
  311. package/dist/export/getCustomFieldFunctions.js.map +0 -1
  312. package/dist/export/getFilename.d.ts +0 -2
  313. package/dist/export/getFilename.d.ts.map +0 -1
  314. package/dist/export/getFilename.js.map +0 -1
  315. package/dist/export/getSelect.d.ts +0 -7
  316. package/dist/export/getSelect.d.ts.map +0 -1
  317. package/dist/export/getSelect.js.map +0 -1
  318. package/dist/getExportCollection.d.ts +0 -7
  319. package/dist/getExportCollection.d.ts.map +0 -1
  320. package/dist/getExportCollection.js +0 -86
  321. package/dist/getExportCollection.js.map +0 -1
  322. /package/dist/{export → utilities}/flattenObject.d.ts +0 -0
@@ -0,0 +1,431 @@
1
+ import { processRichTextField } from './processRichTextField.js';
2
+ export const unflattenObject = ({ data, fields, fromCSVFunctions = {}, req })=>{
3
+ if (!data || typeof data !== 'object') {
4
+ return {};
5
+ }
6
+ const result = {};
7
+ // Sort keys to ensure array indices are processed in order
8
+ const sortedKeys = Object.keys(data).sort((a, b)=>{
9
+ // Extract array indices from flattened keys (e.g., "field_0_subfield" -> "0")
10
+ const aMatch = a.match(/_(\d+)(?:_|$)/);
11
+ const bMatch = b.match(/_(\d+)(?:_|$)/);
12
+ if (aMatch && bMatch && aMatch.index !== undefined && bMatch.index !== undefined) {
13
+ const aBase = a.substring(0, aMatch.index);
14
+ const bBase = b.substring(0, bMatch.index);
15
+ if (aBase === bBase) {
16
+ return (parseInt(aMatch?.[1] ?? '0', 10) || 0) - (parseInt(bMatch?.[1] ?? '0', 10) || 0);
17
+ }
18
+ }
19
+ return a.localeCompare(b);
20
+ });
21
+ for (const flatKey of sortedKeys){
22
+ let value = data[flatKey];
23
+ // Skip undefined values but keep null for required field validation
24
+ if (value === undefined) {
25
+ continue;
26
+ }
27
+ // Check if this is a _relationTo key for a polymorphic relationship
28
+ if (flatKey.endsWith('_relationTo')) {
29
+ const baseKey = flatKey.replace(/_relationTo$/, '');
30
+ const idKey = `${baseKey}_id`;
31
+ // Check if this is a polymorphic relationship field
32
+ const isPolymorphic = fields.some((field)=>field.name === baseKey && field.type === 'relationship' && 'relationTo' in field && Array.isArray(field.relationTo));
33
+ if (isPolymorphic) {
34
+ // Check if we've already processed this field
35
+ if (baseKey in result) {
36
+ continue;
37
+ }
38
+ // If the corresponding _id key is undefined, skip processing entirely
39
+ // This prevents creating empty objects when we should preserve existing data
40
+ if (!(idKey in data) || data[idKey] === undefined) {
41
+ continue;
42
+ }
43
+ }
44
+ }
45
+ // Check if this is a _id key for a polymorphic relationship where _relationTo is undefined
46
+ if (flatKey.endsWith('_id')) {
47
+ const baseKey = flatKey.replace(/_id$/, '');
48
+ const relationToKey = `${baseKey}_relationTo`;
49
+ // Check if this is a polymorphic relationship field
50
+ const isPolymorphic = fields.some((field)=>field.name === baseKey && field.type === 'relationship' && 'relationTo' in field && Array.isArray(field.relationTo));
51
+ if (isPolymorphic) {
52
+ // If the corresponding _relationTo key is undefined, skip processing entirely
53
+ // This prevents creating empty objects when we should preserve existing data
54
+ if (!(relationToKey in data) || data[relationToKey] === undefined) {
55
+ continue;
56
+ }
57
+ }
58
+ }
59
+ // Apply fromCSV function if available
60
+ if (fromCSVFunctions[flatKey]) {
61
+ value = fromCSVFunctions[flatKey]({
62
+ columnName: flatKey,
63
+ data,
64
+ value
65
+ });
66
+ }
67
+ // Parse the flat key into segments
68
+ // Example: "blocks_0_content_text" -> ["blocks", "0", "content", "text"]
69
+ const segments = flatKey.split('_');
70
+ let current = result;
71
+ for(let i = 0; i < segments.length; i++){
72
+ const segment = segments[i];
73
+ if (!segment) {
74
+ continue;
75
+ } // Skip empty segments
76
+ const nextSegment = segments[i + 1];
77
+ const isLast = i === segments.length - 1;
78
+ // Check if next segment is a numeric array index (e.g., "0", "1", "2")
79
+ const isArrayIndex = nextSegment !== undefined && /^\d+$/.test(nextSegment);
80
+ if (isLast) {
81
+ // Special handling for blockType suffix in blocks
82
+ if (segment === 'blockType' && i >= 3) {
83
+ // Pattern: blocks_0_hero_blockType -> set blockType on the block
84
+ const blockFieldName = segments[0] // 'blocks'
85
+ ;
86
+ const isBlockField = fields.some((field)=>field.name === blockFieldName && field.type === 'blocks');
87
+ if (isBlockField && segments[1]?.match(/^\d+$/)) {
88
+ // This is a block type field
89
+ const parent = getParentObject(result, segments.slice(0, 2));
90
+ if (parent && typeof parent === 'object') {
91
+ parent.blockType = value;
92
+ }
93
+ continue;
94
+ }
95
+ }
96
+ // Special handling for relationship fields with _id suffix
97
+ if (segment === 'id' && i > 0) {
98
+ const parentKey = segments[i - 1];
99
+ // Check if the previous segment is an array index
100
+ const prevIsIndex = parentKey ? /^\d+$/.test(parentKey) : false;
101
+ if (!prevIsIndex) {
102
+ // Check if this is a relationship field
103
+ const isRelationship = fields.some((field)=>field.name === parentKey && field.type === 'relationship');
104
+ if (isRelationship) {
105
+ // Check if this is a polymorphic relationship field
106
+ const field = fields.find((f)=>f.name === parentKey && f.type === 'relationship');
107
+ const isPolymorphic = field && 'relationTo' in field && Array.isArray(field.relationTo);
108
+ if (isPolymorphic) {
109
+ // For polymorphic relationships, check for the corresponding _relationTo field
110
+ const relationToKey = segments.slice(0, i).concat('relationTo').join('_');
111
+ const relationToValue = data[relationToKey];
112
+ // This is a polymorphic relationship
113
+ const parent = getParentObject(result, segments.slice(0, i - 1));
114
+ if (parent && parentKey && typeof parent === 'object') {
115
+ // Both fields must be defined to create/update the relationship
116
+ // If either is undefined, skip the field entirely (preserve existing data)
117
+ if (value !== undefined && relationToValue !== undefined) {
118
+ // Check if both are explicitly null
119
+ if (relationToValue === null && value === null) {
120
+ // Only set to null if explicitly null (user typed "null" in CSV)
121
+ parent[parentKey] = null;
122
+ } else if (relationToValue || value) {
123
+ // At least one has a value, create the relationship
124
+ parent[parentKey] = {
125
+ relationTo: relationToValue,
126
+ value
127
+ };
128
+ }
129
+ // If both are empty strings, don't set the field (handled by not meeting the above conditions)
130
+ }
131
+ // If either is undefined, don't set the field at all (preserve existing data)
132
+ }
133
+ continue;
134
+ } else if (!isPolymorphic) {
135
+ // Non-polymorphic relationship
136
+ const parent = getParentObject(result, segments.slice(0, i - 1));
137
+ if (parent && parentKey && typeof parent === 'object') {
138
+ parent[parentKey] = value;
139
+ }
140
+ continue;
141
+ }
142
+ }
143
+ }
144
+ }
145
+ // Special handling for _relationTo suffix (skip it, handled above)
146
+ if (segment === 'relationTo' && i > 0) {
147
+ const parentKey = segments[i - 1];
148
+ if (parentKey && !parentKey.match(/^\d+$/)) {
149
+ const field = fields.find((f)=>f.name === parentKey && f.type === 'relationship');
150
+ const isPolymorphic = field && 'relationTo' in field && Array.isArray(field.relationTo);
151
+ if (isPolymorphic) {
152
+ continue;
153
+ }
154
+ }
155
+ }
156
+ current[segment] = value;
157
+ } else if (isArrayIndex && nextSegment !== undefined) {
158
+ // Initialize array if needed
159
+ if (!current[segment] || !Array.isArray(current[segment])) {
160
+ current[segment] = [];
161
+ }
162
+ const arrayIndex = parseInt(nextSegment);
163
+ const arr = current[segment];
164
+ // Ensure array has sufficient length
165
+ while(arr.length <= arrayIndex){
166
+ arr.push(null);
167
+ }
168
+ // Handle array of objects
169
+ if (arr[arrayIndex] === null || arr[arrayIndex] === undefined) {
170
+ arr[arrayIndex] = {};
171
+ }
172
+ // Check if this is a blocks field with block slug pattern
173
+ const isBlocksField = fields.some((f)=>f.name === segment && f.type === 'blocks');
174
+ if (isBlocksField && i + 3 < segments.length) {
175
+ // Pattern: blocks_0_hero_title where 'hero' is the block slug
176
+ const blockSlug = segments[i + 2];
177
+ const blockFieldName = segments[i + 3];
178
+ if (blockSlug && blockFieldName) {
179
+ const blockObject = arr[arrayIndex];
180
+ // Set the blockType based on the slug
181
+ blockObject.blockType = blockSlug;
182
+ // Handle nested block fields
183
+ if (i + 3 === segments.length - 1) {
184
+ // Direct field on the block
185
+ blockObject[blockFieldName] = value;
186
+ } else {
187
+ // Nested field in the block
188
+ if (!blockObject[blockFieldName] || typeof blockObject[blockFieldName] !== 'object') {
189
+ blockObject[blockFieldName] = {};
190
+ }
191
+ // Continue processing remaining segments
192
+ current = blockObject[blockFieldName];
193
+ i = i + 3; // Skip index, slug, and field name
194
+ continue; // Continue processing the remaining segments (not break!)
195
+ }
196
+ break;
197
+ }
198
+ }
199
+ // If this is the last segment after the index, set the value
200
+ if (i + 2 === segments.length - 1) {
201
+ const lastSegment = segments[segments.length - 1];
202
+ if (lastSegment && arr[arrayIndex] && typeof arr[arrayIndex] === 'object') {
203
+ ;
204
+ arr[arrayIndex][lastSegment] = value;
205
+ }
206
+ break;
207
+ } else if (i + 1 === segments.length - 1) {
208
+ // Direct array value (e.g., tags_0 = "value")
209
+ arr[arrayIndex] = value;
210
+ break;
211
+ } else {
212
+ // Continue traversing into the array element
213
+ current = arr[arrayIndex];
214
+ i++; // skip the index segment
215
+ }
216
+ } else {
217
+ // Regular object property
218
+ // Check if this segment is already set to null (polymorphic relationship already processed)
219
+ if (current[segment] === null && isLast && segment === 'relationTo') {
220
+ continue;
221
+ }
222
+ if (!current[segment] || typeof current[segment] !== 'object' || Array.isArray(current[segment])) {
223
+ current[segment] = {};
224
+ }
225
+ // Handle special cases for polymorphic relationships
226
+ if (segment === 'relationTo' && i > 0 && segments[i - 1]?.match(/^\d+$/)) {
227
+ // This is part of a polymorphic relationship array
228
+ current[segment] = value;
229
+ } else if (typeof current[segment] === 'object' && !Array.isArray(current[segment]) && current[segment] !== null) {
230
+ current = current[segment];
231
+ }
232
+ }
233
+ }
234
+ }
235
+ try {
236
+ // Post-process to handle special structures
237
+ postProcessDocument(result, fields);
238
+ } catch (err) {
239
+ // Log but don't throw - return partially processed result
240
+ req.payload.logger.error({
241
+ err,
242
+ msg: '[plugin-import-export] Error in postProcessDocument'
243
+ });
244
+ }
245
+ return result;
246
+ };
247
+ const getParentObject = (obj, segments)=>{
248
+ let current = obj;
249
+ for(let i = 0; i < segments.length; i++){
250
+ const segment = segments[i];
251
+ const nextSegment = segments[i + 1];
252
+ if (!segment) {
253
+ continue;
254
+ }
255
+ if (nextSegment && /^\d+$/.test(nextSegment)) {
256
+ const arrayIndex = parseInt(nextSegment);
257
+ const arr = current[segment];
258
+ if (Array.isArray(arr) && arr[arrayIndex]) {
259
+ current = arr[arrayIndex];
260
+ i++; // Skip the index
261
+ } else {
262
+ return undefined;
263
+ }
264
+ } else {
265
+ const next = current[segment];
266
+ if (typeof next === 'object' && next !== null && !Array.isArray(next)) {
267
+ current = next;
268
+ } else {
269
+ return undefined;
270
+ }
271
+ }
272
+ }
273
+ return current;
274
+ };
275
+ const postProcessDocument = (doc, fields)=>{
276
+ // Handle localized fields - transform from field_locale to { field: { locale: value } }
277
+ // This is the format Payload stores in the database
278
+ const localizedFields = fields.filter((field)=>field.localized);
279
+ const processedLocalizedFields = new Set();
280
+ for (const field of localizedFields){
281
+ if (processedLocalizedFields.has(field.name)) {
282
+ continue;
283
+ }
284
+ // Look for all locale-specific keys for this field
285
+ const localePattern = new RegExp(`^${field.name}_([a-z]{2}(?:_[A-Z]{2})?)$`);
286
+ const localeData = {};
287
+ const keysToDelete = [];
288
+ for (const [key, value] of Object.entries(doc)){
289
+ const match = key.match(localePattern);
290
+ if (match && match[1]) {
291
+ const locale = match[1];
292
+ localeData[locale] = value;
293
+ keysToDelete.push(key);
294
+ }
295
+ }
296
+ // If we found locale-specific data, restructure it as Payload expects
297
+ if (Object.keys(localeData).length > 0) {
298
+ // Payload stores localized fields as nested objects: { field: { en: 'value', es: 'value' } }
299
+ doc[field.name] = localeData;
300
+ keysToDelete.forEach((key)=>delete doc[key]);
301
+ processedLocalizedFields.add(field.name);
302
+ }
303
+ }
304
+ // Handle number fields with hasMany - convert string arrays to number arrays
305
+ const numberFields = fields.filter((field)=>field.type === 'number' && field.hasMany);
306
+ for (const field of numberFields){
307
+ const value = doc[field.name];
308
+ // Skip if field doesn't exist in document
309
+ if (!(field.name in doc)) {
310
+ continue;
311
+ }
312
+ // Handle comma-separated string (e.g., "1,2,3,4,5")
313
+ if (typeof value === 'string' && value.includes(',')) {
314
+ doc[field.name] = value.split(',').map((v)=>v.trim()).filter((v)=>v !== '').map((v)=>{
315
+ const num = parseFloat(v);
316
+ return isNaN(num) ? 0 : num;
317
+ });
318
+ } else if (Array.isArray(value)) {
319
+ // Filter out null, undefined, and empty string values, then convert to numbers
320
+ doc[field.name] = value.filter((v)=>v !== null && v !== undefined && v !== '').map((v)=>{
321
+ if (typeof v === 'string') {
322
+ const num = parseFloat(v);
323
+ return isNaN(num) ? 0 : num;
324
+ }
325
+ return v;
326
+ });
327
+ } else if (value !== null && value !== undefined && value !== '') {
328
+ const num = typeof value === 'string' ? parseFloat(value) : value;
329
+ doc[field.name] = isNaN(num) ? [] : [
330
+ num
331
+ ];
332
+ } else {
333
+ doc[field.name] = [];
334
+ }
335
+ }
336
+ // Handle relationship fields with hasMany - convert comma-separated IDs to arrays
337
+ const relationshipFields = fields.filter((field)=>(field.type === 'relationship' || field.type === 'upload') && field.hasMany === true && !Array.isArray(field.relationTo));
338
+ for (const field of relationshipFields){
339
+ const value = doc[field.name];
340
+ // Handle comma-separated string of IDs (e.g., "id1,id2,id3")
341
+ if (typeof value === 'string' && value.includes(',')) {
342
+ doc[field.name] = value.split(',').map((v)=>v.trim()).filter((v)=>v !== '');
343
+ } else if (Array.isArray(value)) {
344
+ doc[field.name] = value.filter((v)=>v !== null && v !== undefined && v !== '');
345
+ } else if (value !== null && value !== undefined && value !== '') {
346
+ doc[field.name] = [
347
+ value
348
+ ];
349
+ }
350
+ }
351
+ // Handle polymorphic relationships - transform from flat structure to proper format
352
+ for (const [key, value] of Object.entries(doc)){
353
+ // Handle arrays of polymorphic relationships
354
+ if (Array.isArray(value)) {
355
+ // Check if this array contains polymorphic relationship objects
356
+ const hasPolymorphicItems = value.some((item)=>typeof item === 'object' && item !== null && 'relationTo' in item);
357
+ if (hasPolymorphicItems) {
358
+ // Filter out null/invalid polymorphic items and transform valid ones
359
+ const processedArray = [];
360
+ for(let i = 0; i < value.length; i++){
361
+ const item = value[i];
362
+ if (typeof item === 'object' && item !== null && 'relationTo' in item) {
363
+ const typedItem = item;
364
+ // Skip if both relationTo and value/id are null/empty
365
+ if (!typedItem.relationTo || !typedItem.id && !typedItem.value) {
366
+ continue;
367
+ }
368
+ // Transform from {relationTo: 'collection', id: '123'} to {relationTo: 'collection', value: '123'}
369
+ if ('id' in typedItem) {
370
+ typedItem.value = typedItem.id;
371
+ delete typedItem.id;
372
+ }
373
+ processedArray.push(typedItem);
374
+ } else if (item !== null && item !== undefined) {
375
+ processedArray.push(item);
376
+ }
377
+ }
378
+ // Update the array with filtered results
379
+ if (value.length !== processedArray.length) {
380
+ doc[key] = processedArray.length > 0 ? processedArray : [];
381
+ }
382
+ }
383
+ // For non-polymorphic arrays, preserve null placeholders for sparse arrays
384
+ } else if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
385
+ // Check if this is a single polymorphic relationship
386
+ if ('relationTo' in value && ('id' in value || 'value' in value)) {
387
+ const typedValue = value;
388
+ // If both relationTo and value are null/empty, set the whole field to null
389
+ if (!typedValue.relationTo || !typedValue.id && !typedValue.value) {
390
+ doc[key] = null;
391
+ } else {
392
+ // If it has 'id', transform to 'value'
393
+ if ('id' in typedValue && !('value' in typedValue)) {
394
+ typedValue.value = typedValue.id;
395
+ delete typedValue.id;
396
+ }
397
+ }
398
+ } else {
399
+ // Recursively process nested objects
400
+ postProcessDocument(value, fields);
401
+ }
402
+ }
403
+ }
404
+ // Process rich text fields to ensure proper data types
405
+ const richTextFields = fields.filter((field)=>field.type === 'richText');
406
+ for (const field of richTextFields){
407
+ if (field.name in doc && doc[field.name]) {
408
+ doc[field.name] = processRichTextField(doc[field.name]);
409
+ }
410
+ }
411
+ // Also process rich text fields in blocks
412
+ const blockFields = fields.filter((field)=>field.type === 'blocks');
413
+ for (const field of blockFields){
414
+ if (field.name in doc && Array.isArray(doc[field.name])) {
415
+ const blocks = doc[field.name];
416
+ for (const block of blocks){
417
+ if (!block || typeof block !== 'object') {
418
+ continue;
419
+ }
420
+ // Look for richText fields directly in the block
421
+ for (const [key, value] of Object.entries(block)){
422
+ if (key === 'richText' || typeof key === 'string' && key.includes('richText')) {
423
+ block[key] = processRichTextField(value);
424
+ }
425
+ }
426
+ }
427
+ }
428
+ }
429
+ };
430
+
431
+ //# sourceMappingURL=unflattenObject.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utilities/unflattenObject.ts"],"sourcesContent":["import type { FlattenedField, PayloadRequest } from 'payload'\n\nimport type { FromCSVFunction } from '../types.js'\n\nimport { processRichTextField } from './processRichTextField.js'\n\ntype UnflattenArgs = {\n data: Record<string, unknown>\n fields: FlattenedField[]\n fromCSVFunctions?: Record<string, FromCSVFunction>\n req: PayloadRequest\n}\n\nexport const unflattenObject = ({\n data,\n fields,\n fromCSVFunctions = {},\n req,\n}: UnflattenArgs): Record<string, unknown> => {\n if (!data || typeof data !== 'object') {\n return {}\n }\n\n const result: Record<string, unknown> = {}\n\n // Sort keys to ensure array indices are processed in order\n const sortedKeys = Object.keys(data).sort((a, b) => {\n // Extract array indices from flattened keys (e.g., \"field_0_subfield\" -> \"0\")\n const aMatch = a.match(/_(\\d+)(?:_|$)/)\n const bMatch = b.match(/_(\\d+)(?:_|$)/)\n\n if (aMatch && bMatch && aMatch.index !== undefined && bMatch.index !== undefined) {\n const aBase = a.substring(0, aMatch.index)\n const bBase = b.substring(0, bMatch.index)\n\n if (aBase === bBase) {\n return (parseInt(aMatch?.[1] ?? '0', 10) || 0) - (parseInt(bMatch?.[1] ?? '0', 10) || 0)\n }\n }\n\n return a.localeCompare(b)\n })\n\n for (const flatKey of sortedKeys) {\n let value = data[flatKey]\n\n // Skip undefined values but keep null for required field validation\n if (value === undefined) {\n continue\n }\n\n // Check if this is a _relationTo key for a polymorphic relationship\n if (flatKey.endsWith('_relationTo')) {\n const baseKey = flatKey.replace(/_relationTo$/, '')\n const idKey = `${baseKey}_id`\n\n // Check if this is a polymorphic relationship field\n const isPolymorphic = fields.some(\n (field) =>\n field.name === baseKey &&\n field.type === 'relationship' &&\n 'relationTo' in field &&\n Array.isArray(field.relationTo),\n )\n\n if (isPolymorphic) {\n // Check if we've already processed this field\n if (baseKey in result) {\n // Skipping because already processed\n continue\n }\n\n // If the corresponding _id key is undefined, skip processing entirely\n // This prevents creating empty objects when we should preserve existing data\n if (!(idKey in data) || data[idKey] === undefined) {\n continue\n }\n }\n }\n\n // Check if this is a _id key for a polymorphic relationship where _relationTo is undefined\n if (flatKey.endsWith('_id')) {\n const baseKey = flatKey.replace(/_id$/, '')\n const relationToKey = `${baseKey}_relationTo`\n\n // Check if this is a polymorphic relationship field\n const isPolymorphic = fields.some(\n (field) =>\n field.name === baseKey &&\n field.type === 'relationship' &&\n 'relationTo' in field &&\n Array.isArray(field.relationTo),\n )\n\n if (isPolymorphic) {\n // If the corresponding _relationTo key is undefined, skip processing entirely\n // This prevents creating empty objects when we should preserve existing data\n if (!(relationToKey in data) || data[relationToKey] === undefined) {\n continue\n }\n }\n }\n\n // Apply fromCSV function if available\n if (fromCSVFunctions[flatKey]) {\n value = fromCSVFunctions[flatKey]({\n columnName: flatKey,\n data,\n value,\n })\n }\n\n // Parse the flat key into segments\n // Example: \"blocks_0_content_text\" -> [\"blocks\", \"0\", \"content\", \"text\"]\n const segments = flatKey.split('_')\n let current: Record<string, unknown> = result\n\n for (let i = 0; i < segments.length; i++) {\n const segment = segments[i]\n if (!segment) {\n continue\n } // Skip empty segments\n\n const nextSegment = segments[i + 1]\n const isLast = i === segments.length - 1\n\n // Check if next segment is a numeric array index (e.g., \"0\", \"1\", \"2\")\n const isArrayIndex = nextSegment !== undefined && /^\\d+$/.test(nextSegment)\n\n if (isLast) {\n // Special handling for blockType suffix in blocks\n if (segment === 'blockType' && i >= 3) {\n // Pattern: blocks_0_hero_blockType -> set blockType on the block\n const blockFieldName = segments[0] // 'blocks'\n const isBlockField = fields.some(\n (field) => field.name === blockFieldName && field.type === 'blocks',\n )\n\n if (isBlockField && segments[1]?.match(/^\\d+$/)) {\n // This is a block type field\n const parent = getParentObject(result, segments.slice(0, 2))\n if (parent && typeof parent === 'object') {\n parent.blockType = value\n }\n continue\n }\n }\n\n // Special handling for relationship fields with _id suffix\n if (segment === 'id' && i > 0) {\n const parentKey = segments[i - 1]\n // Check if the previous segment is an array index\n const prevIsIndex = parentKey ? /^\\d+$/.test(parentKey) : false\n\n if (!prevIsIndex) {\n // Check if this is a relationship field\n const isRelationship = fields.some(\n (field) => field.name === parentKey && field.type === 'relationship',\n )\n\n if (isRelationship) {\n // Check if this is a polymorphic relationship field\n const field = fields.find((f) => f.name === parentKey && f.type === 'relationship')\n const isPolymorphic =\n field && 'relationTo' in field && Array.isArray(field.relationTo)\n\n if (isPolymorphic) {\n // For polymorphic relationships, check for the corresponding _relationTo field\n const relationToKey = segments.slice(0, i).concat('relationTo').join('_')\n const relationToValue = data[relationToKey]\n\n // This is a polymorphic relationship\n const parent = getParentObject(result, segments.slice(0, i - 1))\n if (parent && parentKey && typeof parent === 'object') {\n // Both fields must be defined to create/update the relationship\n // If either is undefined, skip the field entirely (preserve existing data)\n if (value !== undefined && relationToValue !== undefined) {\n // Check if both are explicitly null\n if (relationToValue === null && value === null) {\n // Only set to null if explicitly null (user typed \"null\" in CSV)\n parent[parentKey] = null\n } else if (relationToValue || value) {\n // At least one has a value, create the relationship\n parent[parentKey] = {\n relationTo: relationToValue,\n value, // This will be transformed to proper format in postProcess\n }\n }\n // If both are empty strings, don't set the field (handled by not meeting the above conditions)\n }\n // If either is undefined, don't set the field at all (preserve existing data)\n }\n continue\n } else if (!isPolymorphic) {\n // Non-polymorphic relationship\n const parent = getParentObject(result, segments.slice(0, i - 1))\n if (parent && parentKey && typeof parent === 'object') {\n parent[parentKey] = value\n }\n continue\n }\n }\n }\n }\n\n // Special handling for _relationTo suffix (skip it, handled above)\n if (segment === 'relationTo' && i > 0) {\n const parentKey = segments[i - 1]\n if (parentKey && !parentKey.match(/^\\d+$/)) {\n const field = fields.find((f) => f.name === parentKey && f.type === 'relationship')\n const isPolymorphic = field && 'relationTo' in field && Array.isArray(field.relationTo)\n\n if (isPolymorphic) {\n // For polymorphic relationships, this is handled when processing the _id field\n // Skip it entirely\n continue\n }\n }\n }\n\n current[segment] = value\n } else if (isArrayIndex && nextSegment !== undefined) {\n // Initialize array if needed\n if (!current[segment] || !Array.isArray(current[segment])) {\n current[segment] = []\n }\n\n const arrayIndex = parseInt(nextSegment)\n const arr = current[segment] as unknown[]\n\n // Ensure array has sufficient length\n while (arr.length <= arrayIndex) {\n arr.push(null)\n }\n\n // Handle array of objects\n if (arr[arrayIndex] === null || arr[arrayIndex] === undefined) {\n arr[arrayIndex] = {}\n }\n\n // Check if this is a blocks field with block slug pattern\n const isBlocksField = fields.some((f) => f.name === segment && f.type === 'blocks')\n if (isBlocksField && i + 3 < segments.length) {\n // Pattern: blocks_0_hero_title where 'hero' is the block slug\n const blockSlug = segments[i + 2]\n const blockFieldName = segments[i + 3]\n\n if (blockSlug && blockFieldName) {\n const blockObject = arr[arrayIndex] as Record<string, unknown>\n\n // Set the blockType based on the slug\n blockObject.blockType = blockSlug\n\n // Handle nested block fields\n if (i + 3 === segments.length - 1) {\n // Direct field on the block\n blockObject[blockFieldName] = value\n } else {\n // Nested field in the block\n if (!blockObject[blockFieldName] || typeof blockObject[blockFieldName] !== 'object') {\n blockObject[blockFieldName] = {}\n }\n // Continue processing remaining segments\n current = blockObject[blockFieldName] as Record<string, unknown>\n i = i + 3 // Skip index, slug, and field name\n continue // Continue processing the remaining segments (not break!)\n }\n break\n }\n }\n\n // If this is the last segment after the index, set the value\n if (i + 2 === segments.length - 1) {\n const lastSegment = segments[segments.length - 1]\n if (lastSegment && arr[arrayIndex] && typeof arr[arrayIndex] === 'object') {\n ;(arr[arrayIndex] as Record<string, unknown>)[lastSegment] = value\n }\n break\n } else if (i + 1 === segments.length - 1) {\n // Direct array value (e.g., tags_0 = \"value\")\n arr[arrayIndex] = value\n break\n } else {\n // Continue traversing into the array element\n current = arr[arrayIndex] as Record<string, unknown>\n i++ // skip the index segment\n }\n } else {\n // Regular object property\n // Check if this segment is already set to null (polymorphic relationship already processed)\n if (current[segment] === null && isLast && segment === 'relationTo') {\n // This is a relationTo for a polymorphic field that was already set to null\n // Skip creating a new object\n continue\n }\n\n if (\n !current[segment] ||\n typeof current[segment] !== 'object' ||\n Array.isArray(current[segment])\n ) {\n current[segment] = {}\n }\n\n // Handle special cases for polymorphic relationships\n if (segment === 'relationTo' && i > 0 && segments[i - 1]?.match(/^\\d+$/)) {\n // This is part of a polymorphic relationship array\n current[segment] = value\n } else if (\n typeof current[segment] === 'object' &&\n !Array.isArray(current[segment]) &&\n current[segment] !== null\n ) {\n current = current[segment] as Record<string, unknown>\n }\n }\n }\n }\n\n try {\n // Post-process to handle special structures\n postProcessDocument(result, fields)\n } catch (err) {\n // Log but don't throw - return partially processed result\n\n req.payload.logger.error({\n err,\n msg: '[plugin-import-export] Error in postProcessDocument',\n })\n }\n\n return result\n}\n\nconst getParentObject = (\n obj: Record<string, unknown>,\n segments: string[],\n): Record<string, unknown> | undefined => {\n let current: Record<string, unknown> = obj\n\n for (let i = 0; i < segments.length; i++) {\n const segment = segments[i]\n const nextSegment = segments[i + 1]\n\n if (!segment) {\n continue\n }\n\n if (nextSegment && /^\\d+$/.test(nextSegment)) {\n const arrayIndex = parseInt(nextSegment)\n const arr = current[segment] as unknown[]\n\n if (Array.isArray(arr) && arr[arrayIndex]) {\n current = arr[arrayIndex] as Record<string, unknown>\n i++ // Skip the index\n } else {\n return undefined\n }\n } else {\n const next = current[segment]\n if (typeof next === 'object' && next !== null && !Array.isArray(next)) {\n current = next as Record<string, unknown>\n } else {\n return undefined\n }\n }\n }\n\n return current\n}\n\nconst postProcessDocument = (doc: Record<string, unknown>, fields: FlattenedField[]): void => {\n // Handle localized fields - transform from field_locale to { field: { locale: value } }\n // This is the format Payload stores in the database\n const localizedFields = fields.filter((field) => field.localized)\n const processedLocalizedFields = new Set<string>()\n\n for (const field of localizedFields) {\n if (processedLocalizedFields.has(field.name)) {\n continue\n }\n\n // Look for all locale-specific keys for this field\n const localePattern = new RegExp(`^${field.name}_([a-z]{2}(?:_[A-Z]{2})?)$`)\n const localeData: Record<string, unknown> = {}\n const keysToDelete: string[] = []\n\n for (const [key, value] of Object.entries(doc)) {\n const match = key.match(localePattern)\n if (match && match[1]) {\n const locale = match[1]\n localeData[locale] = value\n keysToDelete.push(key)\n }\n }\n\n // If we found locale-specific data, restructure it as Payload expects\n if (Object.keys(localeData).length > 0) {\n // Payload stores localized fields as nested objects: { field: { en: 'value', es: 'value' } }\n doc[field.name] = localeData\n keysToDelete.forEach((key) => delete doc[key])\n processedLocalizedFields.add(field.name)\n }\n }\n\n // Handle number fields with hasMany - convert string arrays to number arrays\n const numberFields = fields.filter((field) => field.type === 'number' && field.hasMany)\n for (const field of numberFields) {\n const value = doc[field.name]\n\n // Skip if field doesn't exist in document\n if (!(field.name in doc)) {\n continue\n }\n\n // Handle comma-separated string (e.g., \"1,2,3,4,5\")\n if (typeof value === 'string' && value.includes(',')) {\n doc[field.name] = value\n .split(',')\n .map((v) => v.trim())\n .filter((v) => v !== '')\n .map((v) => {\n const num = parseFloat(v)\n return isNaN(num) ? 0 : num\n })\n }\n // Handle array of values from indexed columns (e.g., field_0, field_1, etc.)\n else if (Array.isArray(value)) {\n // Filter out null, undefined, and empty string values, then convert to numbers\n doc[field.name] = value\n .filter((v) => v !== null && v !== undefined && v !== '')\n .map((v) => {\n if (typeof v === 'string') {\n const num = parseFloat(v)\n return isNaN(num) ? 0 : num\n }\n return v\n })\n }\n // Handle single value for hasMany (convert to array)\n else if (value !== null && value !== undefined && value !== '') {\n const num = typeof value === 'string' ? parseFloat(value) : value\n doc[field.name] = isNaN(num as number) ? [] : [num]\n }\n // Handle empty/null values - convert to empty array for hasMany\n else {\n doc[field.name] = []\n }\n }\n\n // Handle relationship fields with hasMany - convert comma-separated IDs to arrays\n const relationshipFields = fields.filter(\n (field) =>\n (field.type === 'relationship' || field.type === 'upload') &&\n field.hasMany === true &&\n !Array.isArray(field.relationTo), // Skip polymorphic for now, handled separately\n )\n for (const field of relationshipFields) {\n const value = doc[field.name]\n\n // Handle comma-separated string of IDs (e.g., \"id1,id2,id3\")\n if (typeof value === 'string' && value.includes(',')) {\n doc[field.name] = value\n .split(',')\n .map((v) => v.trim())\n .filter((v) => v !== '')\n }\n // Keep array as-is if already an array\n else if (Array.isArray(value)) {\n doc[field.name] = value.filter((v) => v !== null && v !== undefined && v !== '')\n }\n // Convert single value to array for hasMany\n else if (value !== null && value !== undefined && value !== '') {\n doc[field.name] = [value]\n }\n }\n\n // Handle polymorphic relationships - transform from flat structure to proper format\n for (const [key, value] of Object.entries(doc)) {\n // Handle arrays of polymorphic relationships\n if (Array.isArray(value)) {\n // Check if this array contains polymorphic relationship objects\n const hasPolymorphicItems = value.some(\n (item) => typeof item === 'object' && item !== null && 'relationTo' in item,\n )\n\n if (hasPolymorphicItems) {\n // Filter out null/invalid polymorphic items and transform valid ones\n const processedArray = []\n for (let i = 0; i < value.length; i++) {\n const item = value[i]\n if (typeof item === 'object' && item !== null && 'relationTo' in item) {\n const typedItem = item as Record<string, unknown>\n\n // Skip if both relationTo and value/id are null/empty\n if (!typedItem.relationTo || (!typedItem.id && !typedItem.value)) {\n continue\n }\n\n // Transform from {relationTo: 'collection', id: '123'} to {relationTo: 'collection', value: '123'}\n if ('id' in typedItem) {\n typedItem.value = typedItem.id\n delete typedItem.id\n }\n\n processedArray.push(typedItem)\n } else if (item !== null && item !== undefined) {\n processedArray.push(item)\n }\n }\n\n // Update the array with filtered results\n if (value.length !== processedArray.length) {\n doc[key] = processedArray.length > 0 ? processedArray : []\n }\n }\n // For non-polymorphic arrays, preserve null placeholders for sparse arrays\n }\n // Handle single polymorphic relationships\n else if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n // Check if this is a single polymorphic relationship\n if ('relationTo' in value && ('id' in value || 'value' in value)) {\n const typedValue = value as Record<string, unknown>\n\n // If both relationTo and value are null/empty, set the whole field to null\n if (!typedValue.relationTo || (!typedValue.id && !typedValue.value)) {\n doc[key] = null\n } else {\n // If it has 'id', transform to 'value'\n if ('id' in typedValue && !('value' in typedValue)) {\n typedValue.value = typedValue.id\n delete typedValue.id\n }\n }\n } else {\n // Recursively process nested objects\n postProcessDocument(value as Record<string, unknown>, fields)\n }\n }\n }\n\n // Process rich text fields to ensure proper data types\n const richTextFields = fields.filter((field) => field.type === 'richText')\n for (const field of richTextFields) {\n if (field.name in doc && doc[field.name]) {\n doc[field.name] = processRichTextField(doc[field.name])\n }\n }\n\n // Also process rich text fields in blocks\n const blockFields = fields.filter((field) => field.type === 'blocks')\n for (const field of blockFields) {\n if (field.name in doc && Array.isArray(doc[field.name])) {\n const blocks = doc[field.name] as any[]\n for (const block of blocks) {\n if (!block || typeof block !== 'object') {\n continue\n }\n\n // Look for richText fields directly in the block\n for (const [key, value] of Object.entries(block)) {\n if (key === 'richText' || (typeof key === 'string' && key.includes('richText'))) {\n block[key] = processRichTextField(value)\n }\n }\n }\n }\n }\n}\n"],"names":["processRichTextField","unflattenObject","data","fields","fromCSVFunctions","req","result","sortedKeys","Object","keys","sort","a","b","aMatch","match","bMatch","index","undefined","aBase","substring","bBase","parseInt","localeCompare","flatKey","value","endsWith","baseKey","replace","idKey","isPolymorphic","some","field","name","type","Array","isArray","relationTo","relationToKey","columnName","segments","split","current","i","length","segment","nextSegment","isLast","isArrayIndex","test","blockFieldName","isBlockField","parent","getParentObject","slice","blockType","parentKey","prevIsIndex","isRelationship","find","f","concat","join","relationToValue","arrayIndex","arr","push","isBlocksField","blockSlug","blockObject","lastSegment","postProcessDocument","err","payload","logger","error","msg","obj","next","doc","localizedFields","filter","localized","processedLocalizedFields","Set","has","localePattern","RegExp","localeData","keysToDelete","key","entries","locale","forEach","add","numberFields","hasMany","includes","map","v","trim","num","parseFloat","isNaN","relationshipFields","hasPolymorphicItems","item","processedArray","typedItem","id","typedValue","richTextFields","blockFields","blocks","block"],"mappings":"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"}