TYPO3 TCA显示条件(displayCond)用mysql到MM表

时间:2016-12-24 07:23:50

标签: mysql typo3 extbase typo3-7.6.x

我有一个带有主表的扩展,如果该项已经通过MM表与相关TCA有关系,则该复选框不可用;

'checkbox' => [
  'displayCond' =>'FIELD:uid:!IN:SELECT uid_foreign FROM tx_myext_object_object_mm',
  'exclude' => 0,
  'label' => 'checkbox',
  'config' => [
    'type' => 'check',
    'items' => [
      '1' => [
        '0' => 'LLL:EXT:lang/locallang_core.xlf:labels.enabled'
      ]
    ],
  'default' => 0
  ]
],

可以更正此语法,还是不可能(此代码段不起作用)

1 个答案:

答案 0 :(得分:6)

由于TYPO3 7.6 userFunc可用作显示条件。

在您的情况下,我建议您进行TCA配置:

'checkbox' => [
    'displayCond' =>'USER:VendorName\\Myext\\DisplayConditionMatcher->displayIfTxMyextObjectHasNoMMRelation',
    'exclude' => 1,
    'label' => 'Checkbox',
    'config' => [
        'type' => 'check',
        'default' => 0
    ]
],

一个名为DisplayConditionMatcher.php的PHP类位于您的扩展名EXT:myext / Classes /中,内容如下:

<?php
namespace VendorName\Myext;

/**
 * Class DisplayConditionMatcher
 *
 * @package TYPO3
 * @subpackage tx_myext
 * @author 2016 J.Kummer <typo3 et enobe dot de>
 * @copyright Copyright belongs to the respective authors
 * @license http://www.gnu.org/licenses/gpl.html GNU General Public License, version 3 or later
 */

class DisplayConditionMatcher {

    /**
     * Checks for already existing mm relation of tx_myext_object
     * Returns true, if no mm relation found
     * 
     * @param array $configuration
     * @param \TYPO3\CMS\Backend\Form\FormDataProvider\EvaluateDisplayConditions $evaluateDisplayConditions
     * @return bool
     */
    public function displayIfTxMyextObjectHasNoMMRelation(array $configuration, $evaluateDisplayConditions = null)
    {
        $result = true;
        if (isset($configuration['record']['uid'])) {
            $countRows = $GLOBALS['TYPO3_DB']->exec_SELECTcountRows(
                'uid_foreign',
                'tx_myext_object_object_mm',
                'uid_foreign = ' . intval($configuration['record']['uid'])
            );
            if ($countRows > 0) {
                $result = false;
            }
        }
        if (isset($configuration['conditionParameters'][0]) && $configuration['conditionParameters'][0] === 'negate') {
            $result = !$result;
        }
        return $result;
    }
}

如“TYPO3 CMS TCA参考”中所述,您可以将冒号分隔的其他参数传递给userFunc类型的displayCondition。例如,已经在PHP类中实现的否定:

'displayCond' =>'USER:VendorName\\Myext\\DisplayConditionMatcher->displayIfTxMyextObjectHasNoMMRelation:negate',

根据您的需要调整扩展名,路径和供应商的名称。