payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
98 lines (97 loc) • 34.8 kB
JavaScript
/* eslint-disable no-use-before-define */ "use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
function _export(target, all) {
for(var name in all)Object.defineProperty(target, name, {
enumerable: true,
get: all[name]
});
}
_export(exports, {
fieldAffectsData: function() {
return fieldAffectsData;
},
fieldHasMaxDepth: function() {
return fieldHasMaxDepth;
},
fieldHasSubFields: function() {
return fieldHasSubFields;
},
fieldIsArrayType: function() {
return fieldIsArrayType;
},
fieldIsBlockType: function() {
return fieldIsBlockType;
},
fieldIsGroupType: function() {
return fieldIsGroupType;
},
fieldIsLocalized: function() {
return fieldIsLocalized;
},
fieldIsPresentationalOnly: function() {
return fieldIsPresentationalOnly;
},
fieldSupportsMany: function() {
return fieldSupportsMany;
},
optionIsObject: function() {
return optionIsObject;
},
optionIsValue: function() {
return optionIsValue;
},
optionsAreObjects: function() {
return optionsAreObjects;
},
tabHasName: function() {
return tabHasName;
},
valueIsValueWithRelation: function() {
return valueIsValueWithRelation;
}
});
function valueIsValueWithRelation(value) {
return value !== null && typeof value === 'object' && 'relationTo' in value && 'value' in value;
}
function fieldHasSubFields(field) {
return field.type === 'group' || field.type === 'array' || field.type === 'row' || field.type === 'collapsible';
}
function fieldIsArrayType(field) {
return field.type === 'array';
}
function fieldIsBlockType(field) {
return field.type === 'blocks';
}
function fieldIsGroupType(field) {
return field.type === 'group';
}
function optionIsObject(option) {
return typeof option === 'object';
}
function optionsAreObjects(options) {
return Array.isArray(options) && typeof options?.[0] === 'object';
}
function optionIsValue(option) {
return typeof option === 'string';
}
function fieldSupportsMany(field) {
return field.type === 'select' || field.type === 'relationship';
}
function fieldHasMaxDepth(field) {
return (field.type === 'upload' || field.type === 'relationship') && typeof field.maxDepth === 'number';
}
function fieldIsPresentationalOnly(field) {
return field.type === 'ui';
}
function fieldAffectsData(field) {
return 'name' in field && !fieldIsPresentationalOnly(field);
}
function tabHasName(tab) {
return 'name' in tab;
}
function fieldIsLocalized(field) {
return 'localized' in field && field.localized;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/fields/config/types.ts"],"sourcesContent":["/* eslint-disable no-use-before-define */\nimport type { EditorProps } from '@monaco-editor/react'\nimport type { TFunction } from 'i18next'\nimport type { CSSProperties } from 'react'\n\nimport monacoeditor from 'monaco-editor' // IMPORTANT - DO NOT REMOVE: This is required for pnpm's default isolated mode to work - even though the import is not used. This is due to a typescript bug: https://github.com/microsoft/TypeScript/issues/47663#issuecomment-1519138189. (tsbugisolatedmode)\nimport type React from 'react'\n\nimport type { ConditionalDateProps } from '../../admin/components/elements/DatePicker/types'\nimport type { Props as ErrorProps } from '../../admin/components/forms/Error/types'\nimport type { Description } from '../../admin/components/forms/FieldDescription/types'\nimport type { Props as LabelProps } from '../../admin/components/forms/Label/types'\nimport type { RowLabel } from '../../admin/components/forms/RowLabel/types'\nimport type { RichTextAdapter } from '../../admin/components/forms/field-types/RichText/types'\nimport type { User } from '../../auth'\nimport type { SanitizedCollectionConfig, TypeWithID } from '../../collections/config/types'\nimport type { SanitizedConfig } from '../../config/types'\nimport type { PayloadRequest, RequestContext } from '../../express/types'\nimport type { SanitizedGlobalConfig } from '../../globals/config/types'\nimport type { Payload } from '../../payload'\nimport type { Operation, Where } from '../../types'\n\nexport type FieldHookArgs<T extends TypeWithID = any, P = any, S = any> = {\n  /** The collection which the field belongs to. If the field belongs to a global, this will be null. */\n  collection: SanitizedCollectionConfig | null\n  context: RequestContext\n  /** The data passed to update the document within create and update operations, and the full document itself in the afterRead hook. */\n  data?: Partial<T>\n  /** The field which the hook is running against. */\n  field: FieldAffectingData\n  /** Boolean to denote if this hook is running against finding one, or finding many within the afterRead hook. */\n  findMany?: boolean\n  /** The global which the field belongs to. If the field belongs to a collection, this will be null. */\n  global: SanitizedGlobalConfig | null\n  /** A string relating to which operation the field type is currently executing within. Useful within beforeValidate, beforeChange, and afterChange hooks to differentiate between create and update operations. */\n  operation?: 'create' | 'delete' | 'read' | 'update'\n  /** The full original document in `update` operations. In the `afterChange` hook, this is the resulting document of the operation. */\n  originalDoc?: T\n  /** The document before changes were applied, only in `afterChange` hooks. */\n  previousDoc?: T\n  /** The sibling data of the document before changes being applied, only in `beforeChange` and `afterChange` hook. */\n  previousSiblingDoc?: T\n  /** The previous value of the field, before changes, only in `beforeChange` and `afterChange` hooks. */\n  previousValue?: P\n  /** The Express request object. It is mocked for Local API operations. */\n  req: PayloadRequest\n  /** The sibling data passed to a field that the hook is running against. */\n  siblingData: Partial<S>\n  /** The value of the field. */\n  value?: P\n}\n\nexport type FieldHook<T extends TypeWithID = any, P = any, S = any> = (\n  args: FieldHookArgs<T, P, S>,\n) => P | Promise<P>\n\nexport type FieldAccess<T extends TypeWithID = any, P = any, U = any> = (args: {\n  /**\n   * The incoming data used to `create` or `update` the document with. `data` is undefined during the `read` operation.\n   */\n  data?: Partial<T>\n  /**\n   * The original data of the document before the `update` is applied. `doc` is undefined during the `create` operation.\n   */\n  doc?: T\n  /**\n   * The `id` of the current document being read or updated. `id` is undefined during the `create` operation.\n   */\n  id?: number | string\n  /** The `Express` request object containing the currently authenticated `user` */\n  req: PayloadRequest<U>\n  /**\n   * Immediately adjacent data to this field. For example, if this is a `group` field, then `siblingData` will be the other fields within the group.\n   */\n  siblingData?: Partial<P>\n}) => Promise<boolean> | boolean\n\nexport type Condition<T extends TypeWithID = any, P = any> = (\n  data: Partial<T>,\n  siblingData: Partial<P>,\n  { user }: { user: User },\n) => boolean\n\nexport type FilterOptionsProps<T = any> = {\n  data: T\n  id: number | string\n  relationTo: string\n  siblingData: unknown\n  user: Partial<User>\n}\n\nexport type FilterOptions<T = any> =\n  | ((options: FilterOptionsProps<T>) => Promise<Where | boolean> | Where | boolean)\n  | Where\n  | null\n\ntype Admin = {\n  className?: string\n  components?: {\n    Cell?: React.ComponentType<any>\n    Field?: React.ComponentType<any>\n    Filter?: React.ComponentType<any>\n  }\n  /**\n   * You can programmatically show / hide fields based on what other fields are doing.\n   * This is also run on the server, to determine if the field should be validated.\n   */\n  condition?: Condition\n  description?: Description\n  disableBulkEdit?: boolean\n  disabled?: boolean\n  hidden?: boolean\n  position?: 'sidebar'\n  readOnly?: boolean\n  style?: CSSProperties\n  width?: string\n}\n\nexport type Labels = {\n  plural: Record<string, string> | string\n  singular: Record<string, string> | string\n}\n\nexport type ValidateOptions<TData, TSiblingData, TFieldConfig> = {\n  config: SanitizedConfig\n  data: Partial<TData>\n  id?: number | string\n  operation?: Operation\n  payload?: Payload\n  req?: PayloadRequest\n  siblingData: Partial<TSiblingData>\n  t: TFunction\n  user?: Partial<User>\n} & TFieldConfig\n\n// TODO: Having TFieldConfig as any breaks all type checking / auto-completions for the base ValidateOptions properties.\nexport type Validate<TValue = any, TData = any, TSiblingData = any, TFieldConfig = any> = (\n  value: TValue,\n  options: ValidateOptions<TData, TSiblingData, TFieldConfig>,\n) => Promise<string | true> | string | true\n\nexport type OptionObject = {\n  label: Record<string, string> | string\n  value: string\n}\n\nexport type Option = OptionObject | string\n\nexport interface FieldBase {\n  access?: {\n    create?: FieldAccess\n    read?: FieldAccess\n    update?: FieldAccess\n  }\n  admin?: Admin\n  /** Extension point to add your custom data. */\n  custom?: Record<string, any>\n  defaultValue?: any\n  hidden?: boolean\n  hooks?: {\n    afterChange?: FieldHook[]\n    afterRead?: FieldHook[]\n    beforeChange?: FieldHook[]\n    beforeValidate?: FieldHook[]\n  }\n  index?: boolean\n  label?: Record<string, string> | false | string\n  localized?: boolean\n  name: string\n  required?: boolean\n  saveToJWT?: boolean | string\n  unique?: boolean\n  validate?: Validate\n}\n\nexport type NumberField = FieldBase & {\n  admin?: Admin & {\n    /** Set this property to a string that will be used for browser autocomplete. */\n    autoComplete?: string\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n    /** Set this property to define a placeholder string for the field. */\n    placeholder?: Record<string, string> | string\n    /** Set a value for the number field to increment / decrement using browser controls. */\n    step?: number\n  }\n  /** Maximum value accepted. Used in the default `validation` function. */\n  max?: number\n  /** Minimum value accepted. Used in the default `validation` function. */\n  min?: number\n  type: 'number'\n} & (\n    | {\n        /** Makes this field an ordered array of numbers instead of just a single number. */\n        hasMany: true\n        /** Maximum number of numbers in the numbers array, if `hasMany` is set to true. */\n        maxRows?: number\n        /** Minimum number of numbers in the numbers array, if `hasMany` is set to true. */\n        minRows?: number\n      }\n    | {\n        /** Makes this field an ordered array of numbers instead of just a single number. */\n        hasMany?: false | undefined\n        /** Maximum number of numbers in the numbers array, if `hasMany` is set to true. */\n        maxRows?: undefined\n        /** Minimum number of numbers in the numbers array, if `hasMany` is set to true. */\n        minRows?: undefined\n      }\n  )\n\nexport type TextField = FieldBase & {\n  admin?: Admin & {\n    autoComplete?: string\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n    placeholder?: Record<string, string> | string\n    rtl?: boolean\n  }\n  maxLength?: number\n  minLength?: number\n  type: 'text'\n} & (\n    | {\n        /** Makes this field an ordered array of strings instead of just a single string. */\n        hasMany: true\n        /** Maximum number of strings in the strings array, if `hasMany` is set to true. */\n        maxRows?: number\n        /** Minimum number of strings in the strings array, if `hasMany` is set to true. */\n        minRows?: number\n      }\n    | {\n        /** Makes this field an ordered array of strings instead of just a single string. */\n        hasMany?: false | undefined\n        /** Maximum number of strings in the strings array, if `hasMany` is set to true. */\n        maxRows?: undefined\n        /** Minimum number of strings in the strings array, if `hasMany` is set to true. */\n        minRows?: undefined\n      }\n  )\n\nexport type EmailField = FieldBase & {\n  admin?: Admin & {\n    autoComplete?: string\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n    placeholder?: Record<string, string> | string\n  }\n  type: 'email'\n}\n\nexport type TextareaField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n    placeholder?: Record<string, string> | string\n    rows?: number\n    rtl?: boolean\n  }\n  maxLength?: number\n  minLength?: number\n  type: 'textarea'\n}\n\nexport type CheckboxField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n  }\n  type: 'checkbox'\n}\n\nexport type DateField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n      afterInput?: React.ComponentType<any>[]\n      beforeInput?: React.ComponentType<any>[]\n    }\n    date?: ConditionalDateProps\n    placeholder?: Record<string, string> | string\n  }\n  type: 'date'\n}\n\nexport type GroupField = Omit<FieldBase, 'required' | 'validation'> & {\n  admin?: Admin & {\n    hideGutter?: boolean\n  }\n  fields: Field[]\n  /** Customize generated GraphQL and Typescript schema names.\n   * By default it is bound to the collection.\n   *\n   * This is useful if you would like to generate a top level type to share amongst collections/fields.\n   * **Note**: Top level types can collide, ensure they are unique among collections, arrays, groups, blocks, tabs.\n   */\n  interfaceName?: string\n  type: 'group'\n}\n\nexport type RowAdmin = Omit<Admin, 'description'>\n\nexport type RowField = Omit<FieldBase, 'admin' | 'label' | 'name'> & {\n  admin?: RowAdmin\n  fields: Field[]\n  type: 'row'\n}\n\nexport type CollapsibleField = Omit<FieldBase, 'label' | 'name'> & {\n  admin?: Admin & {\n    initCollapsed?: boolean | false\n  }\n  fields: Field[]\n  label: RowLabel\n  type: 'collapsible'\n}\n\nexport type TabsAdmin = Omit<Admin, 'description'>\n\ntype TabBase = Omit<FieldBase, 'required' | 'validation'> & {\n  description?: Description\n  fields: Field[]\n  interfaceName?: string\n  saveToJWT?: boolean | string\n}\n\nexport type NamedTab = TabBase & {\n  /** Customize generated GraphQL and Typescript schema names.\n   * The slug is used by default.\n   *\n   * This is useful if you would like to generate a top level type to share amongst collections/fields.\n   * **Note**: Top level types can collide, ensure they are unique among collections, arrays, groups, blocks, tabs.\n   */\n  interfaceName?: string\n}\n\nexport type UnnamedTab = Omit<TabBase, 'name'> & {\n  interfaceName?: never\n  label: Record<string, string> | string\n  localized?: never\n}\n\nexport type Tab = NamedTab | UnnamedTab\n\nexport type TabsField = Omit<FieldBase, 'admin' | 'localized' | 'name' | 'saveToJWT'> & {\n  admin?: TabsAdmin\n  tabs: Tab[]\n  type: 'tabs'\n}\n\nexport type TabAsField = Tab & {\n  name?: string\n  type: 'tab'\n}\n\nexport type UIField = {\n  admin: {\n    components?: {\n      Cell?: React.ComponentType<any>\n      Field: React.ComponentType<any>\n      Filter?: React.ComponentType<any>\n    }\n    condition?: Condition\n    disableBulkEdit?: boolean\n    position?: string\n    width?: string\n  }\n  /** Extension point to add your custom data. */\n  custom?: Record<string, any>\n  label?: Record<string, string> | string\n  name: string\n  type: 'ui'\n}\n\nexport type UploadField = FieldBase & {\n  admin?: {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n    }\n  }\n  filterOptions?: FilterOptions\n  maxDepth?: number\n  relationTo: string\n  type: 'upload'\n}\n\ntype CodeAdmin = Admin & {\n  components?: {\n    Error?: React.ComponentType<ErrorProps>\n    Label?: React.ComponentType<LabelProps>\n  }\n  editorOptions?: EditorProps['options']\n  language?: string\n}\n\nexport type CodeField = Omit<FieldBase, 'admin'> & {\n  admin?: CodeAdmin\n  maxLength?: number\n  minLength?: number\n  type: 'code'\n}\n\ntype JSONAdmin = Admin & {\n  components?: {\n    Error?: React.ComponentType<ErrorProps>\n    Label?: React.ComponentType<LabelProps>\n  }\n  editorOptions?: EditorProps['options']\n}\n\nexport type JSONField = Omit<FieldBase, 'admin'> & {\n  admin?: JSONAdmin\n  type: 'json'\n}\n\nexport type SelectField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n    }\n    isClearable?: boolean\n    isSortable?: boolean\n  }\n  hasMany?: boolean\n  options: Option[]\n  type: 'select'\n}\n\ntype SharedRelationshipProperties = FieldBase & {\n  filterOptions?: FilterOptions\n  hasMany?: boolean\n  maxDepth?: number\n  type: 'relationship'\n} & (\n    | {\n        hasMany: true\n        /**\n         * @deprecated Use 'maxRows' instead\n         */\n        max?: number\n        maxRows?: number\n        /**\n         * @deprecated Use 'minRows' instead\n         */\n        min?: number\n        minRows?: number\n      }\n    | {\n        hasMany?: false | undefined\n        /**\n         * @deprecated Use 'maxRows' instead\n         */\n        max?: undefined\n        maxRows?: undefined\n        /**\n         * @deprecated Use 'minRows' instead\n         */\n        min?: undefined\n        minRows?: undefined\n      }\n  )\n\ntype RelationshipAdmin = Admin & {\n  allowCreate?: boolean\n  components?: {\n    Error?: React.ComponentType<ErrorProps>\n    Label?: React.ComponentType<LabelProps>\n  }\n  isSortable?: boolean\n}\nexport type PolymorphicRelationshipField = SharedRelationshipProperties & {\n  admin?: RelationshipAdmin & {\n    sortOptions?: { [collectionSlug: string]: string }\n  }\n  relationTo: string[]\n}\nexport type SingleRelationshipField = SharedRelationshipProperties & {\n  admin?: RelationshipAdmin & {\n    sortOptions?: string\n  }\n  relationTo: string\n}\nexport type RelationshipField = PolymorphicRelationshipField | SingleRelationshipField\n\nexport type ValueWithRelation = {\n  relationTo: string\n  value: number | string\n}\n\nexport function valueIsValueWithRelation(value: unknown): value is ValueWithRelation {\n  return value !== null && typeof value === 'object' && 'relationTo' in value && 'value' in value\n}\n\nexport type RelationshipValue =\n  | (number | string)[]\n  | ValueWithRelation\n  | ValueWithRelation[]\n  | (number | string)\n\nexport type RichTextField<\n  Value extends object = any,\n  AdapterProps = any,\n  ExtraProperties = {},\n> = FieldBase & {\n  admin?: Admin\n  editor?: RichTextAdapter<Value, AdapterProps, AdapterProps>\n  type: 'richText'\n} & ExtraProperties\n\nexport type ArrayField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      RowLabel?: RowLabel\n    } & Admin['components']\n    initCollapsed?: boolean | false\n  }\n  fields: Field[]\n  /** Customize generated GraphQL and Typescript schema names.\n   * By default it is bound to the collection.\n   *\n   * This is useful if you would like to generate a top level type to share amongst collections/fields.\n   * **Note**: Top level types can collide, ensure they are unique among collections, arrays, groups, blocks, tabs.\n   */\n  interfaceName?: string\n  labels?: Labels\n  maxRows?: number\n  minRows?: number\n  type: 'array'\n}\n\nexport type RadioField = FieldBase & {\n  admin?: Admin & {\n    components?: {\n      Error?: React.ComponentType<ErrorProps>\n      Label?: React.ComponentType<LabelProps>\n    }\n    layout?: 'horizontal' | 'vertical'\n  }\n  options: Option[]\n  type: 'radio'\n}\n\nexport type Block = {\n  fields: Field[]\n  /** @deprecated - please migrate to the interfaceName property instead. */\n  graphQL?: {\n    singularName?: string\n  }\n  imageAltText?: string\n  imageURL?: string\n  /** Customize generated GraphQL and Typescript schema names.\n   * The slug is used by default.\n   *\n   * This is useful if you would like to generate a top level type to share amongst collections/fields.\n   * **Note**: Top level types can collide, ensure they are unique among collections, arrays, groups, blocks, tabs.\n   */\n  interfaceName?: string\n  labels?: Labels\n  slug: string\n  /** Extension point to add your custom data. */\n  custom?: Record<string, any>\n}\n\nexport type BlockField = FieldBase & {\n  admin?: Admin & {\n    initCollapsed?: boolean | false\n  }\n  blocks: Block[]\n  defaultValue?: unknown\n  labels?: Labels\n  maxRows?: number\n  minRows?: number\n  type: 'blocks'\n}\n\nexport type PointField = FieldBase & {\n  type: 'point'\n}\n\nexport type Field =\n  | ArrayField\n  | BlockField\n  | CheckboxField\n  | CodeField\n  | CollapsibleField\n  | DateField\n  | EmailField\n  | GroupField\n  | JSONField\n  | NumberField\n  | PointField\n  | RadioField\n  | RelationshipField\n  | RichTextField\n  | RowField\n  | SelectField\n  | TabsField\n  | TextField\n  | TextareaField\n  | UIField\n  | UploadField\n\nexport type FieldAffectingData =\n  | ArrayField\n  | BlockField\n  | CheckboxField\n  | CodeField\n  | DateField\n  | EmailField\n  | GroupField\n  | JSONField\n  | NumberField\n  | PointField\n  | RadioField\n  | RelationshipField\n  | RichTextField\n  | SelectField\n  | TabAsField\n  | TextField\n  | TextareaField\n  | UploadField\n\nexport type NonPresentationalField =\n  | ArrayField\n  | BlockField\n  | CheckboxField\n  | CodeField\n  | CollapsibleField\n  | DateField\n  | EmailField\n  | GroupField\n  | JSONField\n  | NumberField\n  | PointField\n  | RadioField\n  | RelationshipField\n  | RichTextField\n  | RowField\n  | SelectField\n  | TabsField\n  | TextField\n  | TextareaField\n  | UploadField\n\nexport type FieldWithPath = Field & {\n  path?: string\n}\n\nexport type FieldWithSubFields = ArrayField | CollapsibleField | GroupField | RowField\n\nexport type FieldPresentationalOnly = UIField\n\nexport type FieldWithMany = RelationshipField | SelectField\n\nexport type FieldWithMaxDepth = RelationshipField | UploadField\n\nexport function fieldHasSubFields(field: Field): field is FieldWithSubFields {\n  return (\n    field.type === 'group' ||\n    field.type === 'array' ||\n    field.type === 'row' ||\n    field.type === 'collapsible'\n  )\n}\n\nexport function fieldIsArrayType(field: Field): field is ArrayField {\n  return field.type === 'array'\n}\n\nexport function fieldIsBlockType(field: Field): field is BlockField {\n  return field.type === 'blocks'\n}\n\nexport function fieldIsGroupType(field: Field): field is GroupField {\n  return field.type === 'group'\n}\n\nexport function optionIsObject(option: Option): option is OptionObject {\n  return typeof option === 'object'\n}\n\nexport function optionsAreObjects(options: Option[]): options is OptionObject[] {\n  return Array.isArray(options) && typeof options?.[0] === 'object'\n}\n\nexport function optionIsValue(option: Option): option is string {\n  return typeof option === 'string'\n}\n\nexport function fieldSupportsMany(field: Field): field is FieldWithMany {\n  return field.type === 'select' || field.type === 'relationship'\n}\n\nexport function fieldHasMaxDepth(field: Field): field is FieldWithMaxDepth {\n  return (\n    (field.type === 'upload' || field.type === 'relationship') && typeof field.maxDepth === 'number'\n  )\n}\n\nexport function fieldIsPresentationalOnly(field: Field | TabAsField): field is UIField {\n  return field.type === 'ui'\n}\n\nexport function fieldAffectsData(field: Field | TabAsField): field is FieldAffectingData {\n  return 'name' in field && !fieldIsPresentationalOnly(field)\n}\n\nexport function tabHasName(tab: Tab): tab is NamedTab {\n  return 'name' in tab\n}\n\nexport function fieldIsLocalized(field: Field | Tab): boolean {\n  return 'localized' in field && field.localized\n}\n\nexport type HookName =\n  | 'afterChange'\n  | 'afterRead'\n  | 'beforeChange'\n  | 'beforeRead'\n  | 'beforeValidate'\n"],"names":["fieldAffectsData","fieldHasMaxDepth","fieldHasSubFields","fieldIsArrayType","fieldIsBlockType","fieldIsGroupType","fieldIsLocalized","fieldIsPresentationalOnly","fieldSupportsMany","optionIsObject","optionIsValue","optionsAreObjects","tabHasName","valueIsValueWithRelation","value","field","type","option","options","Array","isArray","maxDepth","tab","localized"],"mappings":"AAAA,uCAAuC;;;;;;;;;;;IAqtBvBA,gBAAgB;eAAhBA;;IAVAC,gBAAgB;eAAhBA;;IArCAC,iBAAiB;eAAjBA;;IASAC,gBAAgB;eAAhBA;;IAIAC,gBAAgB;eAAhBA;;IAIAC,gBAAgB;eAAhBA;;IAsCAC,gBAAgB;eAAhBA;;IAZAC,yBAAyB;eAAzBA;;IAVAC,iBAAiB;eAAjBA;;IAZAC,cAAc;eAAdA;;IAQAC,aAAa;eAAbA;;IAJAC,iBAAiB;eAAjBA;;IA0BAC,UAAU;eAAVA;;IA1NAC,wBAAwB;eAAxBA;;;AAAT,SAASA,yBAAyBC,KAAc;IACrD,OAAOA,UAAU,QAAQ,OAAOA,UAAU,YAAY,gBAAgBA,SAAS,WAAWA;AAC5F;AAqKO,SAASZ,kBAAkBa,KAAY;IAC5C,OACEA,MAAMC,IAAI,KAAK,WACfD,MAAMC,IAAI,KAAK,WACfD,MAAMC,IAAI,KAAK,SACfD,MAAMC,IAAI,KAAK;AAEnB;AAEO,SAASb,iBAAiBY,KAAY;IAC3C,OAAOA,MAAMC,IAAI,KAAK;AACxB;AAEO,SAASZ,iBAAiBW,KAAY;IAC3C,OAAOA,MAAMC,IAAI,KAAK;AACxB;AAEO,SAASX,iBAAiBU,KAAY;IAC3C,OAAOA,MAAMC,IAAI,KAAK;AACxB;AAEO,SAASP,eAAeQ,MAAc;IAC3C,OAAO,OAAOA,WAAW;AAC3B;AAEO,SAASN,kBAAkBO,OAAiB;IACjD,OAAOC,MAAMC,OAAO,CAACF,YAAY,OAAOA,SAAS,CAAC,EAAE,KAAK;AAC3D;AAEO,SAASR,cAAcO,MAAc;IAC1C,OAAO,OAAOA,WAAW;AAC3B;AAEO,SAAST,kBAAkBO,KAAY;IAC5C,OAAOA,MAAMC,IAAI,KAAK,YAAYD,MAAMC,IAAI,KAAK;AACnD;AAEO,SAASf,iBAAiBc,KAAY;IAC3C,OACE,AAACA,CAAAA,MAAMC,IAAI,KAAK,YAAYD,MAAMC,IAAI,KAAK,cAAa,KAAM,OAAOD,MAAMM,QAAQ,KAAK;AAE5F;AAEO,SAASd,0BAA0BQ,KAAyB;IACjE,OAAOA,MAAMC,IAAI,KAAK;AACxB;AAEO,SAAShB,iBAAiBe,KAAyB;IACxD,OAAO,UAAUA,SAAS,CAACR,0BAA0BQ;AACvD;AAEO,SAASH,WAAWU,GAAQ;IACjC,OAAO,UAAUA;AACnB;AAEO,SAAShB,iBAAiBS,KAAkB;IACjD,OAAO,eAAeA,SAASA,MAAMQ,SAAS;AAChD"}