Files
payload/test/plugin-import-export/seed/index.ts
Patrik 6d768748a0 fix(plugin-import-export): csv export for polymorphic relationship fields (#12926)
### What?

Fixes CSV export support for polymorphic relationship and upload fields.

### Why?

Polymorphic fields in Payload use a `{ relationTo, value }` structure.
The previous implementation incorrectly accessed `.id` directly on the
top-level object, which caused issues depending on query depth or data
shape. This led to missing or invalid values in exported CSVs.

### How?

- Updated getCustomFieldFunctions to safely access relationTo and
value.id from polymorphic fields

- Ensured `hasMany` polymorphic fields export each related ID and
relationTo as separate CSV columns
2025-06-25 11:44:31 -04:00

191 lines
4.0 KiB
TypeScript

import type { Payload } from 'payload'
import { devUser } from '../../credentials.js'
import { richTextData } from './richTextData.js'
export const seed = async (payload: Payload): Promise<boolean> => {
payload.logger.info('Seeding data...')
try {
const user = await payload.create({
collection: 'users',
data: {
email: devUser.email,
password: devUser.password,
name: 'name value',
},
})
// Seed posts
const posts = []
for (let i = 0; i < 2; i++) {
const post = await payload.create({
collection: 'posts',
data: {
title: `Post ${i}`,
},
})
posts.push(post)
}
// create pages
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Title ${i}`,
group: {
array: [{ field1: 'test' }],
},
},
})
}
for (let i = 0; i < 5; i++) {
const doc = await payload.create({
collection: 'pages',
data: {
title: `Localized ${i}`,
localized: 'en test',
},
locale: 'en',
})
await payload.update({
collection: 'pages',
id: doc.id,
data: {
localized: 'es test',
},
locale: 'es',
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Array ${i}`,
array: [
{
field1: 'foo',
field2: 'bar',
},
{
field1: 'foo',
field2: 'baz',
},
],
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Array Subfield ${i}`,
array: [
{
field1: 'foo',
field2: 'bar',
},
{
field1: 'foo',
field2: 'baz',
},
],
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
author: user.id,
title: `Virtual ${i}`,
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
customRelationship: user.id,
title: `Custom ${i}`,
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `hasMany Number ${i}`,
hasManyNumber: [0, 1, 1, 2, 3, 5, 8, 13, 21],
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Blocks ${i}`,
blocks: [
{
blockType: 'hero',
title: 'test',
},
{
blockType: 'content',
richText: richTextData,
},
],
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `JSON ${i}`,
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Jobs ${i}`,
},
})
}
for (let i = 0; i < 5; i++) {
await payload.create({
collection: 'pages',
data: {
title: `Polymorphic ${i}`,
hasOnePolymorphic: {
relationTo: 'posts',
value: posts[0]?.id ?? '',
},
hasManyPolymorphic: [
{
relationTo: 'users',
value: user.id,
},
{
relationTo: 'posts',
value: posts[1]?.id ?? '',
},
],
},
})
}
return true
} catch (err) {
console.error(err)
return false
}
}