4

我想为 TYPO3 CMS 7.6 创建一个自己的 extbase 扩展。扩展必须以不同的语言运行。我发现,存储库匹配仅适用于非本地化记录。

我的存储库功能如下所示:

public function findNew() {
  $query = $this->createQuery();
  $query->getQuerySettings()->setRespectSysLanguage(true);
  $query->matching($query->equals('new', 1));
  return $query->execute();
}

这个函数说:显示所有新的记录= 1

示例:我有一条未激活“新建”复选框的默认记录。现在我创建此记录的本地化版本并将“新建”复选框设置为激活。

如果我以默认语言执行 findNew() 函数,记录将不会显示。如果我用另一种语言执行该功能,即使设置了“New”标志,记录也不会显示!

换句话说:匹配只影响默认/父记录。

我正在使用以下配置设置:

config {
  sys_language_mode = strict
  sys_language_overlay = hideNonTranslated
}

[编辑:] 这是完整的生成 SQL 查询:

SELECT tx_extension_domain_model_table.*
FROM
tx_extension_domain_model_table
WHERE
  tx_extension_domain_model_table.new = '1'
  AND (
    tx_extension_domain_model_table.sys_language_uid = -1
    OR (
      tx_extension_domain_model_table.sys_language_uid = 1
      AND tx_extension_domain_model_table.l10n_parent = 0
    )
    OR (
      tx_extension_domain_model_table.sys_language_uid = 0
      AND tx_extension_domain_model_table.uid IN (
        SELECT tx_extension_domain_model_table.l10n_parent
        FROM tx_extension_domain_model_table
        WHERE tx_extension_domain_model_table.l10n_parent > 0
          AND tx_extension_domain_model_table.sys_language_uid = 1
          AND tx_extension_domain_model_table.deleted = 0
      )
    )
  )
  AND tx_extension_domain_model_table.deleted = 0
  AND tx_extension_domain_model_table.t3ver_state <= 0
  AND tx_extension_domain_model_table.pid <> -1
  AND tx_extension_domain_model_table.hidden = 0
  AND tx_extension_domain_model_table.starttime <= 1459780380
  AND (tx_extension_domain_model_table.endtime = 0 OR     tx_extension_domain_model_table.endtime > 1459780380)
ORDER BY tx_extension_domain_model_table.sorting ASC

...以及重要的部分:

    AND (
        tx_extension_domain_model_table.sys_language_uid = -1
    OR (
      tx_extension_domain_model_table.sys_language_uid = 1
      AND tx_extension_domain_model_table.l10n_parent = 0
    )
    OR (
      tx_extension_domain_model_table.sys_language_uid = 0
      AND tx_extension_domain_model_table.uid IN (
        SELECT tx_extension_domain_model_table.l10n_parent
        FROM tx_extension_domain_model_table
        WHERE tx_extension_domain_model_table.l10n_parent > 0
          AND tx_extension_domain_model_table.sys_language_uid = 1
          AND tx_extension_domain_model_table.deleted = 0
      )
    )
  )

这解释了我的问题。TYPO3 在本地化时不会在 sys_language_uid = 1 中寻找 new = 1 ......但为什么呢?

问题:这是错误还是功能?

4

1 回答 1

0

这是 extbase 中的一个错误,请参阅此处了解更多信息:https ://forge.typo3.org/issues/57272

于 2016-07-07T21:32:48.813 回答