2016-04-27 3 views
0

Ich kann das Datenbankfeld nicht "sortieren", wenn ich ein Extbase-Objekt zum Repository hinzufüge.TYPO3 CommandController: Wie legt man das Tabellenfeld "Sortierung" des Extbase-Objekts fest?

Andere Datenbankfelder korrekt ausgefüllt sind, aber irgendwie $this->language->setSorting(8)setzen nicht das Datenbankfeld bis 8. In meinem Fall Sortierung der Wert ist immer 0.

Mein Code in meinem TYPO3 CommandController Aussehen sieht wie folgt:

//Inject vars 
/** 
* @var \TYPO3\CMS\Extbase\Object\ObjectManager 
* @inject 
*/ 
protected $objectManager; 

/** 
* @var \TYPO3\CMS\Extbase\Persistence\Generic\PersistenceManager 
* @inject 
*/ 
protected $persistenceManager; 

/** 
* @var \TYPO3\CMS\Extbase\Persistence\Generic\Typo3QuerySettings 
* @inject 
*/ 
protected $querySettings; 

/** 
* languageRepository 
* 
* @var \ITCENTER\ItcJobcenter\Domain\Repository\LanguageRepository 
* @inject 
*/ 
protected $languageRepository; 

public function languageApiCommand($storagePid, \DateTime $dateTime = null) { 

    // Set storagePid from "Command Controller Task" $storagePid 
    $this->storagePid = $storagePid; 

    // Query-Settings (PID) 
    $this->querySettings->setStoragePageIds(array($this->storagePid)); 
    $this->languageRepository->setDefaultQuerySettings($this->querySettings); 

    // Create my neue language object 
    $this->language = $this->objectManager->get('\ITCENTER\ItcJobcenter\Domain\Model\Language'); 
    $this->language->setTitle("MyT itle"); 
    $this->language->setPid($this->storagePid); 
    $this->language->setSorting(8); 
    $this->languageRepository->add($this->language); 

    // Persist new language object to database 
    $this->persistenceManager->persistAll(); 
} 

Datenbankfeld heißt Sortieren und ist vorhanden! Ich habe auch eine Variable "Sortierung" und Getter/Setter im LanguageModel!

Mein Sprachmodell hat diese zusätzliche codepart:

/** 
* @var integer 
*/ 
protected $sorting; 

/** 
* Get sorting 
* 
* @return integer 
*/ 
public function getSorting() { 
    return $this->sorting; 
} 

/** 
* Set sorting 
* 
* @param integer $sorting sorting 
* @return void 
*/ 
public function setSorting($sorting) { 
    $this->sorting = $sorting; 
} 

Antwort

1

Arbeitslösung:

Schließlich fand ich den fehlenden Teil von mir.

Wenn Sie ein Datenbankfeld aus einem FrontendPlugin oder einem CommandControllerTask wie in meinem Fall manipulieren wollen „Sortierung“ Sie müssen eine Definition hinzufügen dieses „Feld“ im TCA der entsprechenden Tabelle.

daher innerhalb der columns => array(--INSERT HERE--) Definition etwas wie folgt hinzu:

columns => array(
    'sorting' => array(
     'config' => array(
      'type' => 'passthrough', 
     ), 
    ), 
) 
+0

sehr interessant nur Sie setzen Ihre Sortierung auf 8 fest ... Ich würde gerne wissen, wie man eine native Sortierung (Drag'n Drop oder Pfeile) in der Listenansicht verwendet, um meine Artikel zu sortieren und die Tabellenfeldsortierung zu füllen, vielleicht haben Sie eine Ahnung. .. – webMan

1

nicht das Feld manuell Sortierung einstellen Sie. Verwenden Sie die DataHandler-Klasse zum Sortieren.

Wenn Sie die Sortierposition eines Eintrags ändern wollen wie ein comand verwenden:

$cmd[ tablename ][ uid ][ command ] = value 

Sie können mehr Informationen hier finden:

https://docs.typo3.org/typo3cms/CoreApiReference/ApiOverview/Typo3CoreEngine/Database/Index.html

Mit dem COMAND bewegen Sie können die Position eines Eintrags in der Tabelle vertauschen.

Wenn Sie das COMAND erstellt Sie es mit diesem Code ausführen kann

$tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler'); 
$tce->stripslashes_values = 0; 
$tce->start(array(), $cmd); 
$tce->process_cmdmap(); 

Dies ist die gleiche comand TYPO3 zum Sortieren einer Liste im Backend verwendet. Typo3 Backend

Weitere Informationen über die Datahandler Anruf Blick hier:

https://docs.typo3.org/typo3cms/CoreApiReference/ApiOverview/Typo3CoreEngine/UsingDataHandler/Index.html

Beispiel Repository:

class SortedRepository extends \TYPO3\CMS\Extbase\Persistence\Repository 
{ 
    protected $defaultOrderings = array(
     'sorting' => \TYPO3\CMS\Extbase\Persistence\QueryInterface::ORDER_ASCENDING, 
    ); 

    public function moveUp($entity) 
    { 

     $tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler'); 
     $tce->stripslashes_values = 0; 
     $entityTwoBefore = $this->getTwoBefore($entity); 

     if ($entityTwoBefore != null) { 
      //category is minimum 3 
      //can set over UID 
      $cmd[$this->getTableName($entity)][$entity->getUid()]['move']= 0-$entityTwoBefore->getUid(); 
     } else { 
      //can only set over pid 
      $cmd[$this->getTableName($entity)][$entity->getUid()]['move']= Util::getStorageID(); 
     } 

     $tce->start(array(), $cmd); 
     $tce->process_cmdmap(); 

    } 

    public function moveDown($entity) 
    { 
     $tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler'); 
     $tce->stripslashes_values = 0; 

     $nextEntity = $this->getNext($entity); 

     if ($nextEntity != null) { 
      $cmd[$this->getTableName($entity)][$entity->getUid()]['move'] = 0 - $nextEntity->getUid(); 
     } 

     $tce->start(array(), $cmd); 
     $tce->process_cmdmap(); 
    } 

    private function getNext($entity) 
    { 
     $entities = $this->findAll(); 
     $match = false; 
     foreach ($entities as $entityFor) { 
      if ($entityFor->getUid() == $entity->getUid()) { 
       $match = true; 
       continue; 
      } 
      if ($match == true) { 
       return $entityFor; 
      } 
     } 
    } 

    private function getBefore($entity) 
    { 
     $entities = array_reverse($this->findAll()->toArray()); 
     $match = false; 
     foreach ($entities as $entityFor) { 
      if ($entityFor->getUid() == $entity->getUid()) { 
       $match = true; 
       continue; 
      } 
      if ($match == true) { 
       return $entityFor; 
      } 
     } 
    } 

    private function getTwoBefore($entity) 
    { 
     $entityTwoBefore = null; 
     $entityBefore = $this->getBefore($entity); 
     if ($entityBefore != null) { 
      $entityTwoBefore = $this->getBefore($entityBefore); 
     } 

     return $entityTwoBefore; 

    } 

    /** 
    * Return the current tablename 
    * 
    * @return string 
    */ 
    private function getTableName($entity) { 

     /** @var DataMapper $dataMapper */ 
     $dataMapper = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Extbase\\Persistence\\Generic\\Mapper\\DataMapper'); 

     return $dataMapper->getDataMap(get_class($entity))->getTableName(); 
    } 
} 

Wenn Ihr Repository erweitert SortedRepository Sie die Methoden moveUp verwenden können() und moveDown().

Hinweis: Die DB-Tabelle benötigt das Feld "Sortierung". Sie müssen sie in der Datei ext_tables.sql und im TCA der Modellklasse:

ext_tables.sql:

# 
# Table structure for table 'tx_extension_domain_model_subcategory' 
# 
CREATE TABLE tx_extension_domain_model_subcategory (

    uid int(11) NOT NULL auto_increment, 
    pid int(11) DEFAULT '0' NOT NULL, 

    name varchar(255) DEFAULT '' NOT NULL, 

    tstamp int(11) unsigned DEFAULT '0' NOT NULL, 
    crdate int(11) unsigned DEFAULT '0' NOT NULL, 
    cruser_id int(11) unsigned DEFAULT '0' NOT NULL, 
    deleted tinyint(4) unsigned DEFAULT '0' NOT NULL, 
    hidden tinyint(4) unsigned DEFAULT '0' NOT NULL, 
    starttime int(11) unsigned DEFAULT '0' NOT NULL, 
    endtime int(11) unsigned DEFAULT '0' NOT NULL, 

    t3ver_oid int(11) DEFAULT '0' NOT NULL, 
    t3ver_id int(11) DEFAULT '0' NOT NULL, 
    t3ver_wsid int(11) DEFAULT '0' NOT NULL, 
    t3ver_label varchar(255) DEFAULT '' NOT NULL, 
    t3ver_state tinyint(4) DEFAULT '0' NOT NULL, 
    t3ver_stage int(11) DEFAULT '0' NOT NULL, 
    t3ver_count int(11) DEFAULT '0' NOT NULL, 
    t3ver_tstamp int(11) DEFAULT '0' NOT NULL, 
    t3ver_move_id int(11) DEFAULT '0' NOT NULL, 
    sorting int(11) DEFAULT '0' NOT NULL, 

    sys_language_uid int(11) DEFAULT '0' NOT NULL, 
    l10n_parent int(11) DEFAULT '0' NOT NULL, 
    l10n_diffsource mediumblob, 

    PRIMARY KEY (uid), 
    KEY parent (pid), 
    KEY t3ver_oid (t3ver_oid,t3ver_wsid), 
KEY language (l10n_parent,sys_language_uid) 

); 

Und im TCA des Modells:

<?php 
return array(
    'ctrl' => array(
     'title' => 'LLL:EXT:pdvdownloadportal/Resources/Private/Language/locallang_db.xlf:tx_pdvdownloadportal_domain_model_subcategory', 
     'label' => 'name', 
     'tstamp' => 'tstamp', 
     'crdate' => 'crdate', 
     'cruser_id' => 'cruser_id', 
     'dividers2tabs' => TRUE, 
     'versioningWS' => 2, 
     'versioning_followPages' => TRUE, 
     'sortby' => 'sorting', 
    ... 
Verwandte Themen