## Description Fixes https://github.com/payloadcms/payload/issues/7671 Copy of https://github.com/payloadcms/payload/pull/8003 to 2.0 - [x] I have read and understand the [CONTRIBUTING.md](https://github.com/payloadcms/payload/blob/main/CONTRIBUTING.md) document in this repository. ## Type of change <!-- Please delete options that are not relevant. --> - [x] Bug fix (non-breaking change which fixes an issue) ## Checklist: - [x] I have added tests that prove my fix is effective or that my feature works - [x] Existing test suite passes locally with my changes
201 lines
3.8 KiB
TypeScript
201 lines
3.8 KiB
TypeScript
import type { CollectionConfig } from '../../../../packages/payload/src/collections/config/types'
|
|
|
|
import { AfterInput } from './AfterInput'
|
|
import { BeforeInput } from './BeforeInput'
|
|
import CustomError from './CustomError'
|
|
import CustomLabel from './CustomLabel'
|
|
import { defaultText, textFieldsSlug } from './shared'
|
|
|
|
const TextFields: CollectionConfig = {
|
|
admin: {
|
|
useAsTitle: 'text',
|
|
},
|
|
defaultSort: 'id',
|
|
fields: [
|
|
{
|
|
name: 'text',
|
|
required: true,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'localizedText',
|
|
localized: true,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'i18nText',
|
|
admin: {
|
|
description: {
|
|
en: 'en description',
|
|
es: 'es description',
|
|
},
|
|
placeholder: {
|
|
en: 'en placeholder',
|
|
es: 'es placeholder',
|
|
},
|
|
},
|
|
label: {
|
|
en: 'Text en',
|
|
es: 'Text es',
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'defaultString',
|
|
defaultValue: defaultText,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'defaultEmptyString',
|
|
defaultValue: '',
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'defaultFunction',
|
|
defaultValue: () => defaultText,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'defaultAsync',
|
|
defaultValue: async (): Promise<string> => {
|
|
return new Promise((resolve) =>
|
|
setTimeout(() => {
|
|
resolve(defaultText)
|
|
}, 1),
|
|
)
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'overrideLength',
|
|
label: 'Override the 40k text length default',
|
|
maxLength: 50000,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'fieldWithDefaultValue',
|
|
defaultValue: async () => {
|
|
const defaultValue = new Promise((resolve) => setTimeout(() => resolve('some-value'), 1000))
|
|
|
|
return defaultValue
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'dependentOnFieldWithDefaultValue',
|
|
hooks: {
|
|
beforeChange: [
|
|
({ data }) => {
|
|
return data?.fieldWithDefaultValue || ''
|
|
},
|
|
],
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'customLabel',
|
|
admin: {
|
|
components: {
|
|
Label: CustomLabel,
|
|
},
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'customError',
|
|
admin: {
|
|
components: {
|
|
Error: CustomError,
|
|
},
|
|
},
|
|
minLength: 3,
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'beforeAndAfterInput',
|
|
admin: {
|
|
components: {
|
|
afterInput: [AfterInput],
|
|
beforeInput: [BeforeInput],
|
|
},
|
|
},
|
|
type: 'text',
|
|
},
|
|
{
|
|
name: 'hasMany',
|
|
type: 'text',
|
|
hasMany: true,
|
|
},
|
|
{
|
|
name: 'validatesHasMany',
|
|
type: 'text',
|
|
hasMany: true,
|
|
minLength: 3,
|
|
},
|
|
{
|
|
name: 'localizedHasMany',
|
|
type: 'text',
|
|
hasMany: true,
|
|
localized: true,
|
|
},
|
|
{
|
|
name: 'withMinRows',
|
|
type: 'text',
|
|
hasMany: true,
|
|
minRows: 2,
|
|
},
|
|
{
|
|
name: 'withMaxRows',
|
|
type: 'text',
|
|
hasMany: true,
|
|
maxRows: 4,
|
|
},
|
|
{
|
|
name: 'disableListColumnText',
|
|
type: 'text',
|
|
admin: {
|
|
disableListColumn: true,
|
|
disableListFilter: false,
|
|
},
|
|
},
|
|
{
|
|
name: 'disableListFilterText',
|
|
type: 'text',
|
|
admin: {
|
|
disableListColumn: false,
|
|
disableListFilter: true,
|
|
},
|
|
},
|
|
{
|
|
name: 'array',
|
|
type: 'array',
|
|
fields: [
|
|
{
|
|
name: 'texts',
|
|
type: 'text',
|
|
hasMany: true,
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: 'blocks',
|
|
type: 'blocks',
|
|
blocks: [
|
|
{
|
|
slug: 'block',
|
|
fields: [
|
|
{
|
|
name: 'texts',
|
|
type: 'text',
|
|
hasMany: true,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
],
|
|
slug: textFieldsSlug,
|
|
}
|
|
|
|
export default TextFields
|