File¶
New in version 13.0
When using the file
type, TYPO3 takes care of
generating the according database field.
A developer does not need to define this field in an extension's
ext_
file.
The TCA type file
creates a field where files can be attached to
the record. The according database field
is generated automatically.
See also
Table of contents
Examples¶
Properties of the TCA column type file
¶
-
allowed
¶ -
- Type
- string / array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Proc. / Display
One or more (comma-separated) of the following reserved strings:
common-
image- types - Gets replaced with the value from
$GLOBALS
.['TYPO3_ CONF_ VARS'] ['GFX'] ['imagefile_ ext'] common-
text- types - Gets replaced with the value from
$GLOBALS
.['TYPO3_ CONF_ VARS'] ['SYS'] ['textfile_ ext'] common-
media- types - Gets replaced with the value from
$GLOBALS
.['TYPO3_ CONF_ VARS'] ['SYS'] ['mediafile_ ext']
Additionally, specific allowed file extensions can be added (comma separated), for example
'common-
.image- types, common- text- types, gz, zip You can also use the array notation of allowed file extensions, for example
['jpg','png','svg']
or['common-
.image- types', 'gz', 'zip'] New in version 13.1.0
Due to a bug, the array notation only properly works since TYPO3 13.1.0 and v12.4.1 and upwards. Use the string notation for earlier versions instead.
-
appearance
¶ -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display
Has information about the appearance of child-records, namely:
- collapseAll (boolean)
- Show all child-records collapsed (if false, all are expanded)
- expandSingle (boolean)
- Show only one child-record expanded each time. If a collapsed record is clicked, the currently open one collapses and the clicked one expands.
- createNewRelationLinkTitle (string or LLL reference)
- Overrides the link text and title of the "Create new relation" button with a localized string. Only useful, if the element browser is enabled.
- addMediaLinkTitle (string or LLL reference)
- Overrides the link text and title of the "Add media by URL" button with a localized string. Only useful, if the element browser is enabled.
- uploadFilesLinkTitle (string or LLL reference)
- Overrides the link text and title of the "Select & upload files" button with a localized string. Only useful, if the element browser is enabled.
- useSortable (boolean)
- Activate drag & drop.
- showPossibleLocalizationRecords (boolean)
- Show unlocalized files which are in the original language, but not yet localized.
- showAllLocalizationLink (boolean)
- Defines whether to show the "localize all records" link to fetch untranslated records from the original language.
- showSynchronizationLink (boolean)
- Defines whether to show a "synchronize" link to update to a 1:1 translation with the original language.
- enabledControls (array)
- Associative array with the keys 'info', 'new', 'dragdrop', 'sort', 'hide', 'delete', 'localize'. If the accordant values are set to a boolean value (true or false), the control is shown or hidden in the header of each record.
- headerThumbnail (array)
-
Defines whether a thumbnail should be rendered in the inline element's header. This is used by the file abstraction layer to render a preview of the related image. Can contain image processing instructions like
width
andheight
.- field (required)
- The table column name, which contains the uid of the image reference. Usually this is
uid_
.local - width
- The width of the thumbnail.
- height
- The height of the thumbnail.
- fileUploadAllowed (boolean)
-
Defines whether the button "Select & upload file" should be rendered. This can be used for file fields to directly upload files and create a reference to the file. The button is limited to file fields using File Abstraction Layer. It will only appear to backend users which have write access to the user upload folder. By default this folder is
fileadmin/
but it can be changed in User TSconfig usinguser_ upload options.
. See the TSconfig reference.default Upload Folder The button is shown by default unless this option is set to
false
. - fileByUrlAllowed (boolean)
- Defines whether the button "Add media by URL" should be rendered. This button is used to include media URLs from, for example, Vimeo or YouTube.
- elementBrowserEnabled (boolean)
- Hides or displays the element browser button in inline records
This property can also be overridden by page TSconfig.
-
behaviour
¶ -
-
allow
¶Language Synchronization -
- Type
- boolean
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['behaviour']['allowLanguageSynchronization']
- Scope
- Proc.
Allows an editor to select in a localized record whether the value is copied over from default or source language record, or if the field has an own value in the localization. If set to true and if the table supports localization and if a localized record is edited, this setting enables FieldWizard LocalizationStateSelector: Two or three radio buttons shown below the field input. The state of this is stored in a json encoded array in the database table called
l10n_
. It tells the DataHandler which fields of the localization records should be kept in sync if the underlying default or source record changes.state This property can also be overridden by page TSconfig.
-
disable
¶Moving Children With Parent -
- Type
- boolean
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['behaviour']['disableMovingChildrenWithParent']
- Scope
- Proc.
Default false. Disables that child records get moved along with their parent records. Usually if in a parent-child relation a parent record is moved to a different page (eg. via cut+paste from clipboard), the children are relocated along with the parent. This flag disables the child move.
This property can also be overridden by page TSconfig.
-
enable
¶Cascading Delete -
- Type
- boolean
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['behaviour']['enableCascadingDelete']
- Scope
- Proc.
- Default
- true
Usually when the parent record is deleted all attached
sys_
are deleted. This default behaviour can be disabled here.file_ references This property can also be overridden by page TSconfig.
-
-
disallowed
¶ -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Proc. / Display
An array of file extensions that are not allowed even though they are listed in the property
allowed
, for example['doc','docx']
.
-
field
¶Information -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display
Show information between an element label and the main element input area. Configuration works identical to the "fieldWizard" property, no default configuration in the core exists (yet). In contrast to "fieldWizard", HTML returned by fieldInformation is limited, see FormEngine docs for more details.
-
field
¶Wizard -
-
default
¶Language Differences -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['fieldWizard']['defaultLanguageDifferences']
For details see defaultLanguageDifferences.
-
localization
¶State Selector -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['fieldWizard']['localizationStateSelector']
For details see localizationStateSelector.
-
other
¶Language Content -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']['fieldWizard']['otherLanguageContent']
For details see otherLanguageContent.
-
-
maxitems
¶ -
- Type
- integer > 0
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display / Proc.
Maximum number of files that can be attached. Defaults to a high value. JavaScript record validation prevents the record from being saved if the limit is not satisfied.
This property can also be overridden by page TSconfig.
-
minitems
¶ -
- Type
- integer > 0
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display
- Types
- group, inline
- Default
- 0
Minimum number of attached files. JavaScript record validation prevents the record from being saved if the limit is not satisfied.
This property can also be overridden by page TSconfig.
Example, exactly one image has to be attached:
// After
'columns' => [
'image' => [
'label' => 'My one and only image',
'config' => [
'type' => 'file',
'minitems' => 1,
'maxitems' => 1,
'allowed' => 'common-image-types'
],
],
],
-
override
¶Child Tca -
- Type
- array
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display
Override the TCA of the
sys_
records representing the files attached to this record.file_ reference
-
read
¶Only -
- Type
- boolean
- Path
- $GLOBALS['TCA'][$table]['columns'][$field]['config']
- Scope
- Display
The files attached to this record are displayed but cannot be changed in the backend form.
This property can also be overridden by page TSconfig.
Warning
This property affects only the display. It is still possible to write to those fields when using the DataHandler.