303 lines
6.4 KiB
TypeScript
303 lines
6.4 KiB
TypeScript
import type { CollectionConfig } from '../../src/collections/config/types';
|
|
import { devUser } from '../credentials';
|
|
import { buildConfig } from '../buildConfig';
|
|
|
|
export interface Relation {
|
|
id: string;
|
|
name: string;
|
|
}
|
|
|
|
const openAccess = {
|
|
create: () => true,
|
|
read: () => true,
|
|
update: () => true,
|
|
delete: () => true,
|
|
};
|
|
|
|
const collectionWithName = (collectionSlug: string): CollectionConfig => {
|
|
return {
|
|
slug: collectionSlug,
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
name: 'name',
|
|
type: 'text',
|
|
},
|
|
],
|
|
};
|
|
};
|
|
|
|
export const slug = 'posts';
|
|
export const relationSlug = 'relation';
|
|
export const pointSlug = 'point';
|
|
export const customIdSlug = 'custom-id';
|
|
export const customIdNumberSlug = 'custom-id-number';
|
|
export const errorOnHookSlug = 'error-on-hooks';
|
|
|
|
export default buildConfig({
|
|
endpoints: [
|
|
{
|
|
path: '/send-test-email',
|
|
method: 'get',
|
|
handler: async (req, res) => {
|
|
await req.payload.sendEmail({
|
|
from: 'dev@payloadcms.com',
|
|
to: devUser.email,
|
|
subject: 'Test Email',
|
|
html: 'This is a test email.',
|
|
// to recreate a failing email transport, add the following credentials
|
|
// to the `email` property of `payload.init()` in `../dev.ts`
|
|
// the app should fail to send the email, but the error should be handled without crashing the app
|
|
// transportOptions: {
|
|
// host: 'smtp.ethereal.email',
|
|
// port: 587,
|
|
// },
|
|
});
|
|
|
|
res.status(200).send('Email sent');
|
|
},
|
|
},
|
|
],
|
|
collections: [
|
|
{
|
|
slug,
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
name: 'title',
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'description',
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'number',
|
|
type: 'number',
|
|
},
|
|
{
|
|
name: 'fakeLocalization',
|
|
type: 'text',
|
|
// field is localized even though the config localization is not on
|
|
localized: true,
|
|
},
|
|
// Relationship
|
|
{
|
|
name: 'relationField',
|
|
type: 'relationship',
|
|
relationTo: relationSlug,
|
|
},
|
|
// Relation hasMany
|
|
{
|
|
name: 'relationHasManyField',
|
|
type: 'relationship',
|
|
relationTo: relationSlug,
|
|
hasMany: true,
|
|
},
|
|
// Relation multiple relationTo
|
|
{
|
|
name: 'relationMultiRelationTo',
|
|
type: 'relationship',
|
|
relationTo: [relationSlug, 'dummy'],
|
|
},
|
|
// Relation multiple relationTo hasMany
|
|
{
|
|
name: 'relationMultiRelationToHasMany',
|
|
type: 'relationship',
|
|
relationTo: [relationSlug, 'dummy'],
|
|
hasMany: true,
|
|
},
|
|
{
|
|
name: 'restrictedField',
|
|
type: 'text',
|
|
access: {
|
|
read: () => false,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
slug: pointSlug,
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
type: 'point',
|
|
name: 'point',
|
|
},
|
|
],
|
|
},
|
|
collectionWithName(relationSlug),
|
|
{
|
|
slug: 'dummy',
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
type: 'text',
|
|
name: 'title',
|
|
},
|
|
{
|
|
type: 'text',
|
|
name: 'name',
|
|
access: {
|
|
read: () => false,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
slug: customIdSlug,
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
name: 'id',
|
|
type: 'text',
|
|
},
|
|
{
|
|
type: 'row',
|
|
fields: [
|
|
{
|
|
name: 'name',
|
|
type: 'text',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
{
|
|
slug: customIdNumberSlug,
|
|
access: openAccess,
|
|
fields: [
|
|
{
|
|
name: 'id',
|
|
type: 'number',
|
|
},
|
|
{
|
|
name: 'name',
|
|
type: 'text',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
slug: errorOnHookSlug,
|
|
access: openAccess,
|
|
hooks: {
|
|
beforeChange: [({ originalDoc }) => {
|
|
if (originalDoc?.errorBeforeChange) {
|
|
throw new Error('Error Before Change Thrown');
|
|
}
|
|
}],
|
|
afterDelete: [({ doc }) => {
|
|
if (doc?.errorAfterDelete) {
|
|
throw new Error('Error After Delete Thrown');
|
|
}
|
|
}],
|
|
},
|
|
fields: [
|
|
{
|
|
name: 'text',
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'errorBeforeChange',
|
|
type: 'checkbox',
|
|
},
|
|
{
|
|
name: 'errorAfterDelete',
|
|
type: 'checkbox',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
onInit: async (payload) => {
|
|
await payload.create({
|
|
collection: 'users',
|
|
data: {
|
|
email: devUser.email,
|
|
password: devUser.password,
|
|
},
|
|
});
|
|
|
|
const rel1 = await payload.create({
|
|
collection: relationSlug,
|
|
data: {
|
|
name: 'name',
|
|
},
|
|
});
|
|
const rel2 = await payload.create({
|
|
collection: relationSlug,
|
|
data: {
|
|
name: 'name2',
|
|
},
|
|
});
|
|
|
|
await payload.create({
|
|
collection: pointSlug,
|
|
data: {
|
|
point: [10, 20],
|
|
},
|
|
});
|
|
|
|
// Relation - hasMany
|
|
await payload.create({
|
|
collection: slug,
|
|
data: {
|
|
title: 'rel to hasMany',
|
|
relationHasManyField: rel1.id,
|
|
},
|
|
});
|
|
await payload.create({
|
|
collection: slug,
|
|
data: {
|
|
title: 'rel to hasMany 2',
|
|
relationHasManyField: rel2.id,
|
|
},
|
|
});
|
|
|
|
// Relation - relationTo multi
|
|
await payload.create({
|
|
collection: slug,
|
|
data: {
|
|
title: 'rel to multi',
|
|
relationMultiRelationTo: {
|
|
relationTo: relationSlug,
|
|
value: rel2.id,
|
|
},
|
|
},
|
|
});
|
|
|
|
// Relation - relationTo multi hasMany
|
|
await payload.create({
|
|
collection: slug,
|
|
data: {
|
|
title: 'rel to multi hasMany',
|
|
relationMultiRelationToHasMany: [
|
|
{
|
|
relationTo: relationSlug,
|
|
value: rel1.id,
|
|
},
|
|
{
|
|
relationTo: relationSlug,
|
|
value: rel2.id,
|
|
},
|
|
],
|
|
},
|
|
});
|
|
|
|
await payload.create({
|
|
collection: customIdSlug,
|
|
data: {
|
|
id: 'test',
|
|
name: 'inside row',
|
|
},
|
|
});
|
|
|
|
await payload.create({
|
|
collection: customIdNumberSlug,
|
|
data: {
|
|
id: 123,
|
|
name: 'name',
|
|
},
|
|
});
|
|
},
|
|
});
|