Skip to content

Commit

Permalink
[Backport 12.4] [TASK] Merge properties back into columns page (#1174)
Browse files Browse the repository at this point in the history
[TASK] Merge properties back into columns page

Releases: main, 12.4

Co-authored-by: lina.wolf <[email protected]>
  • Loading branch information
github-actions[bot] and linawolf authored Sep 26, 2024
1 parent fa0c5b2 commit 83ae77b
Show file tree
Hide file tree
Showing 14 changed files with 378 additions and 392 deletions.
227 changes: 227 additions & 0 deletions Documentation/Columns/DisplayConditions.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,227 @@
.. include:: /Includes.rst.txt

.. _columns-displaycond:

=================================
Display conditions in TCA columns
=================================

Display conditions (:confval:`$GLOBALS['TCA'][$table]['columns'][$field][displayCond] <columns-displayCond>`)
can be used to only display the affected field if certain other fields are set
to certain values.

Conditions can be grouped and nested using boolean operators :code:`AND` or :code:`OR` as
array keys. See examples below.

.. contents:: Table of contents

.. _columns-displaycond-rules:

Rules in display conditions
===========================

A rule is a string divided into several parts by ":" (colons). The first part is
the rule-type and the subsequent parts depend on the rule type.

The following rules are available:

FIELD
This evaluates based on another field's value in the record.

- Part 1 is the field name

- Part 2 is the evaluation type. These are the possible options:

REQ
Requires the field to have a "true" value. False values are "" (blank string) and 0 (zero).
Everything else is true. For the REQ evaluation type Part 3 of the rules string must be the string "true"
or "false". If "true" then the rule returns "true" if the evaluation is true. If "false" then the rule
returns "true" if the evaluation is false.

**> / < / >= / <=**
Evaluates if the field value is greater than, less than the value in "Part 3"

**= / !=**
Evaluates if the field value is equal to value in "Part 3"

**IN / !IN**
Evaluates if the field value is in the comma list equal to value in "Part 3"

**- / !-**
Evaluates if the field value is in the range specified by value in "Part 3" ([min] - [max])

**BIT / !BIT**
Evaluates if the bit specified by the value in "Part 3" is set in the field's value
(considered as an integer)

- Part 3 is a comma separated list of string or numeric values

REC:NEW:true
This will show the field for new records which have not been saved yet.

REC:NEW:false
This will show the field for existing records which have already been saved.

HIDE\_FOR\_NON\_ADMINS
This will hide the field for all non-admin users while admins can see it.
Useful for FlexForm container fields which are not supposed to be edited directly via the FlexForm but
rather through some other interface.

USER
userFunc call with a fully qualified class name.

Additional parameters can be passed separated by colon:
:php:`USER:Evoweb\\Example\\User\\MyConditionMatcher->checkHeader:some:more:info`

The following arguments are passed as array to the userFunc:

- :php:`record`: the currently edited record
- :php:`flexContext`: details about the FlexForm if the condition is used in one
- :php:`flexformValueKey`: `vDEF`
- :php:`conditionParameters`: additional parameters

The called method is expected to return a :php:`bool` value: :php:`true` if the field should be displayed, :php:`false` otherwise.

VERSION:IS
Evaluate if a record is a "versioned" record from workspaces.

- Part 1 is the type:

IS
Part 2 is "true" or "false": If true, the field is shown only if the record is a version (pid == -1).
Example to show a field in "Live" workspace only: :php:`VERSION:IS:false`

In FlexForm, display conditions can be attached to single fields in sheets, to sheets itself, to flex section fields
and to flex section container element fields. :code:`FIELD` references can be prefixed with a sheet name to
reference a field from a neighbor sheet, see examples below.

.. tip::
Fields used in a conditions should have the column option
:confval:`columns-onChange` set to reload.

.. _columns-displaycond-examples:

Examples for display conditions
===============================

.. _columns-displaycond-examples-basic:

Basic display condition
------------------------

This example will require the field named "tx\_templavoila\_ds" to be true, otherwise the field for which this rule
is set will not be displayed:

.. code-block:: php
'displayCond' => 'FIELD:tx_templavoila_ds:REQ:true',
.. _columns-displaycond-examples-combined:

Combining conditions
--------------------

Multiple conditions can be combined:

.. code-block:: php
'displayCond' => [
'AND' => [
'FIELD:tx_templavoila_ds:REQ:true',
'FIELD:header:=:Headline',
],
],
An example with multiple values and :code:`OR`:

.. code-block:: php
:caption: EXT:my_extension/Configuration/TCA/Overrides/tx_mask_field.php
$GLOBALS['TCA']['tx_mask_table']['columns']['tx_mask_field']['displayCond']['OR'] = [
'FIELD:tx_mask_otherfield:=:1',
'FIELD:tx_mask_otherfield:=:2',
'FIELD:tx_mask_otherfield:=:4',
];
This is the same as:

.. code-block:: php
:caption: EXT:my_extension/Configuration/TCA/Overrides/tx_mask_field.php
$GLOBALS['TCA']['tx_mask_table']['columns']['tx_mask_field']['displayCond']
= 'FIELD:tx_mask_otherfield:IN:1,2,4';
.. _columns-displaycond-examples-complex:

A complex example
-----------------

Going further the next example defines the following conditions: for the
"example_field" field to be displayed, the content element must be in the
default language. Furthermore it must be a text-type element or have the
headline "Example" defined:

.. code-block:: php
'displayCond' => [
'AND' => [
'FIELD:sys_language_uid:=:0',
'OR' => [
'FIELD:CType:=:text',
'FIELD:header:=:Example'
]
]
],
.. _columns-displaycond-examples-flexform:

A complex example in a FlexForm
-------------------------------

Using :code:`OR` and :code:`AND` within FlexForms works like this:

.. code-block:: xml
<displayCond>
<and>
<value1>FIELD:sys_language_uid:=:0</value1>
<or>
<value1>FIELD:CType:=:text</value1>
<value2>FIELD:header:=:Example</value2>
</or>
</and>
</displayCond>
.. _columns-displaycond-examples-flexform-value:

Access values in a flexform
---------------------------

Flex form fields can access field values from various different sources:

.. code-block:: xml
<!-- Hide field if value of record field "header" is not "true" -->
<displayCond>FIELD:parentRec.header:REQ:true</displayCond>
<!-- Hide field if value of parent record field "field_1" is not "foo" -->
<displayCond>FIELD:parentRec.field_1:!=:foo</displayCond>
<!-- Hide field if value of neighbour field "flexField_1 on same sheet is not "foo" -->
<displayCond>FIELD:flexField_1:!=:foo</displayCond>
<!-- Hide field if value of field "flexField_1" from sheet "sheet_1" is not "foo" -->
<displayCond>FIELD:sheet_1.flexField_1:!=:foo</displayCond>
.. _columns-displaycond-technical:

Technical background
====================

The display conditions are implemented in class
:php:`\TYPO3\CMS\Backend\Form\FormDataProvider\EvaluateDisplayConditions`,
which is a :ref:`FormDataProvider <t3coreapi:FormEngine-DataCompiling>`.
It can be used for fields directly in the record as well as for
FlexForm values.
60 changes: 60 additions & 0 deletions Documentation/Columns/Examples.rst
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
.. include:: /Includes.rst.txt

.. _columns-example:

========
Examples
========
Expand All @@ -16,6 +18,8 @@ The following examples all can be found in the
Styleguide; select_single_12
pair: selectSingle; Images

.. _columns-example-drop down:

Select drop-down for records represented by images
==================================================

Expand All @@ -40,3 +44,59 @@ Inline relation (IRRE) spanning multiple tables
Inline relation to a foreign table:

.. include:: /CodeSnippets/Inline1n1nInline1.rst.txt

.. _tca_example_translated_text_2:

Example: prefixLangTitle
========================

The following example can be found in the :ref:`extension styleguide
<styleguide>`. On translating a record in a new language the content of the
field gets copied to the target language. It get prefixed with
:code:`[Translate to <language name>:]`.

.. include:: /Images/Rst/TranslatedText2.rst.txt

The language mode is defined as follows:

.. include:: /CodeSnippets/TranslatedText2.rst.txt

.. _tca_example_l10n_mode:

Disable the prefixLangTitle for the header field in tt_content
==============================================================

Use the default behaviour instead of :php:`prefixLangTitle`: the field will
be copied without a prepended string.

.. code-block:: php
:caption: EXT:my_sitepackage/Configuration/TCA/Overrides/tt_content.php
$GLOBALS['TCA']['tt_content']['columns']['header']['l10n_mode'] = ''
.. _tca_example_translated_select_single_13:

Select field with `defaultAsReadonly`
=====================================

The following field has the option :php:`'l10n_display' => 'defaultAsReadonly'`
set:

.. include:: /Images/Rst/TranslatedSelectSingle13.rst.txt

Complete TCA definition of the field:

.. include:: /CodeSnippets/SelectSingle13.rst.txt

.. _tca_example_translated_select_single_8:

Translated field without `l10n_display` definition
==================================================

The following has no :php:`'l10n_display'` definition:

.. include:: /Images/Rst/TranslatedSelectSingle8.rst.txt

Complete TCA definition of the field:

.. include:: /CodeSnippets/SelectSingle8.rst.txt
55 changes: 34 additions & 21 deletions Documentation/Columns/Index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -14,30 +14,43 @@ submitted data.
Each field can be configured as a certain "type" (**required!**), for instance a checkbox, an input field, or a
database relation selector box. Each type allows a set of additional "renderType"s (**sometimes required!**). Each "type" and "renderType" combination comes with a set of additional properties.

The basic structure looks like this:

.. code-block:: php
'columns' => [
'aField' => [
'label' => 'someLabel',
'config' => [
'type' => 'aType',
'renderType' => 'aRenderType',
// ...
],
// ...
],
],
Properties on the level parallel to "label" are valid for all "type" and "renderType" combinations.
.. contents:: Content on this page

.. toctree::
:caption: Subpages
:titlesonly:
:glob:

*

.. _columns-example-basic:

Example: A basic input field
============================

The basic structure of a field definition in TCA looks like this:

.. include:: /Images/Rst/Input1.rst.txt

.. include:: /CodeSnippets/Input1.rst.txt

You can find this example in the :ref:`extension styleguide <styleguide>`.

Properties on the level parallel to :confval:`label <t3tca:columns-label>`
are valid for all "type" and "renderType" combinations.
They are listed below. The list of properties within the "config" section depend on the specific "type" and "renderType"
combination and are explained in detail in the :ref:`['columns']['config'] <columns-types>` section.

.. _columns-properties:

.. toctree::
:titlesonly:
Properties of `columns` section of TCA
======================================

.. confval-menu::
:name: columns
:display: table
:type:
:Scope:

Examples
Properties/Index
.. include:: _Properties/_*.rst.txt
:show-buttons:
28 changes: 0 additions & 28 deletions Documentation/Columns/Properties/Config.rst

This file was deleted.

Loading

0 comments on commit 83ae77b

Please sign in to comment.