Fixes #9882 and #9691 In 2.0, we would accept data coming back from an update operation and then reflect those changes in UI. However, in 3.0, we did not do that anymore - meaning you could change a document with hooks in `beforeChange` or `afterChange`, but then not see the changes made on the server. This PR updates the way that `mergeServerFormState` works, and adds a property to optionally allow values from server form state - which can then be used in the `onSuccess` form handler which may need to define new field values.
77 lines
2.3 KiB
TypeScript
77 lines
2.3 KiB
TypeScript
import { fileURLToPath } from 'node:url'
|
|
import path from 'path'
|
|
const filename = fileURLToPath(import.meta.url)
|
|
const dirname = path.dirname(filename)
|
|
import type { SanitizedConfig } from 'payload'
|
|
|
|
import { APIError } from 'payload'
|
|
|
|
import { buildConfigWithDefaults } from '../buildConfigWithDefaults.js'
|
|
import { AfterOperationCollection } from './collections/AfterOperation/index.js'
|
|
import { BeforeChangeHooks } from './collections/BeforeChange/index.js'
|
|
import { BeforeValidateCollection } from './collections/BeforeValidate/index.js'
|
|
import ChainingHooks from './collections/ChainingHooks/index.js'
|
|
import ContextHooks from './collections/ContextHooks/index.js'
|
|
import { DataHooks } from './collections/Data/index.js'
|
|
import Hooks, { hooksSlug } from './collections/Hook/index.js'
|
|
import NestedAfterReadHooks from './collections/NestedAfterReadHooks/index.js'
|
|
import Relations from './collections/Relations/index.js'
|
|
import TransformHooks from './collections/Transform/index.js'
|
|
import Users, { seedHooksUsers } from './collections/Users/index.js'
|
|
import { DataHooksGlobal } from './globals/Data/index.js'
|
|
export const HooksConfig: Promise<SanitizedConfig> = buildConfigWithDefaults({
|
|
admin: {
|
|
importMap: {
|
|
baseDir: path.resolve(dirname),
|
|
},
|
|
},
|
|
collections: [
|
|
BeforeChangeHooks,
|
|
BeforeValidateCollection,
|
|
AfterOperationCollection,
|
|
ContextHooks,
|
|
TransformHooks,
|
|
Hooks,
|
|
NestedAfterReadHooks,
|
|
ChainingHooks,
|
|
Relations,
|
|
Users,
|
|
DataHooks,
|
|
],
|
|
globals: [DataHooksGlobal],
|
|
endpoints: [
|
|
{
|
|
path: '/throw-to-after-error',
|
|
method: 'get',
|
|
handler: () => {
|
|
throw new APIError("I'm a teapot", 418)
|
|
},
|
|
},
|
|
],
|
|
hooks: {
|
|
afterError: [() => console.log('Running afterError hook')],
|
|
},
|
|
onInit: async (payload) => {
|
|
await seedHooksUsers(payload)
|
|
await payload.create({
|
|
collection: hooksSlug,
|
|
data: {
|
|
fieldBeforeValidate: false,
|
|
collectionBeforeValidate: false,
|
|
fieldBeforeChange: false,
|
|
collectionBeforeChange: false,
|
|
fieldAfterChange: false,
|
|
collectionAfterChange: false,
|
|
collectionBeforeRead: false,
|
|
fieldAfterRead: false,
|
|
collectionAfterRead: false,
|
|
},
|
|
})
|
|
},
|
|
typescript: {
|
|
outputFile: path.resolve(dirname, 'payload-types.ts'),
|
|
},
|
|
})
|
|
|
|
export default HooksConfig
|