FlexForm-Daten sortiert aus einem Select-Feld ausgeben

FlexForm-Daten sortiert aus einem Select-Feld ausgeben

Mit FlexForm kann man leicht Plugins mit Feldern zur Steuerung der Ausgabe erweitern. Ob das jetzt einfache Input-Felder, Checkboxen oder Kind-Elemente mittels IRRE sind, spielt keine Rolle. Alles, was per TCA-Konfiguration geht, geht mit FlexForms.

Wenn man aber eine Select-Box per selectMultipleSideBySide rendert, um dem Plugin eine Selektion von Datensätzen mitzugeben, wird der Wert dieses Feldes in ein String abgespeichert. Dieser String besteht aus kommaseparierten UIDs der ausgewählten Datensätze und zwar in der Reihenfolge, wie sie in dem Select-Feld sortiert wurden (zum Beispiel "4,2,1,3").
Diese Datensätze möchte man nun auch im Frontend genau in dieser Reihenfolge ausgelesen haben und stößt somit auf das Problem, dass keine geeignete Query in Extbase existiert, um dies zu bewerkstelligen.

TYPO3 bringt zum Glück für solche Probleme eine API für Doctrine DBAL mit, die es uns erlaubt mit dem QueryBuilder entsprechende Queries auf die Datenbank loszulassen. Klar könnte man auch den String in ein Array mittels explode teilen und dann für jede enthaltene UID eine einzelne findByUid-Abfrage erstellen, aber darunter würde die Performance leiden.

<?php declare(strict_types=1); namespace Vendor\Package\Domain\Repository; use Vendor\Package\Domain\Model\Item; use TYPO3\CMS\Core\Database\ConnectionPool; use TYPO3\CMS\Core\Database\Query\QueryBuilder; use TYPO3\CMS\Core\Utility\GeneralUtility; use TYPO3\CMS\Extbase\Persistence\Generic\Mapper\DataMapper; /** * ItemRepository */ class ItemRepository { private const TABLE = 'tx_package_domain_model_item'; /** * @var DataMapper */ protected DataMapper $dataMapper; /** * @var QueryBuilder|null */ protected ?QueryBuilder $queryBuilder = null; /** * Constructor */ public function __construct(DataMapper $dataMapper) { $this->dataMapper = $dataMapper; $this->queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable(self::TABLE); } /** * @param string $uidList * @return array */ public function findByUidList(string $uidList): array { $uids = GeneralUtility::intExplode(',', $uidList, true); if (count($uids) === 0) { return []; } $records = $this->queryBuilder ->select('*') ->from(self::TABLE) ->where($this->queryBuilder->expr()->in('uid', $uids)) ->add('orderBy', 'FIELD(uid,' . implode(',', $uids) . ')') ->execute() ->fetchAll(); return $this->dataMapper->map(Item::class, $records); } }

In der Funktion findByUidList wird eine relativ einfache Query um eine orderBy-Anweisung erweitert, in der die UIDs übergeben werden.

Nicht wundern, dass wir am Anfang der Funktion den String erst per explode auseinandernehmen, ihn dann aber für das orderBy per implode zu einem ähnlichen String zusammenfügen. Mit GeneralUtility::intExplode führen wir nicht nur ein explode aus, sondern casten die dort vorkommenden Werte direkt zu Integer, so dass wir sichergehen können, dass sich in dem String nur UIDs befinden. Mit dem dritten Parameter von intExplode werden sogar noch "leere" Werte direkt entfernt.

TYPO3: Finding pages in mixed mode

In TYPO3, Mixed Mode refers to translated pages that contain content only partially related to the corresponding content in the main language. This is indicated in the backend by an error message. But...

Zum Beitrag

Extbase Extensions: Think extensibility with data, site and language

Today, I have a small request for the TYPO3 extension authors out there: Make sure your extensions are extensible. This will also promote the distribution of the corresponding plugins.

Zum Beitrag

SQL: Show all tables sorted by size in descending order

Lately I've been using the SQL command more often to find out which tables in the TYPO3 database are the largest. I've published the snippet once.

Zum Beitrag

TYPO3 12 with CKEditor 5: Styles in a single selection

If you set a link in the RTE in TYPO3, you may have to choose between different link classes, for example to create buttons in the frontend. What's new in TYPO3 12 is that you can select not just one...

Zum Beitrag

Null-Safe Operator in the TYPO3 area

With the introduction of PHP8, problems with undefined arrays or variables in general can arise in many places. Here are a few examples and simple solutions.

Zum Beitrag

Delete the first/last lines of a (SQL) file

There isn't much to say about the following commands. Sometimes it can be useful to delete the first (or last) X lines from a file. And if the file is too large to open with a conventional program, a...

Zum Beitrag