[TYPO3-german] Extbase: Model mit eigener Methode -> wie von array nach objext umwandeln?
Robert Wildling
rowild at gmx.net
Mon Sep 9 19:23:48 CEST 2013
Hallo, lieber Thomas,
Danke für deine ausführliche Antwort und deinen Input! iterator_to_array
kannte ich nicht!!
Zum EventController:
Bis jetzt war mir noch nicht klar, wie ich 2 oder mehrere controller
verwenden kann. Ich hab so das Gefühl, dass dein Code Snippet mir da ein
Lämpchen anschaltet! Werde das gleich mal probieren! Herzlichen Dank
dafür!!!
Schönen Abend noch!
Robert
> Hi Robert
>
> Ja, ich hatte hatte eine solche Anforderung noch nie. Auch keine
> Erfahrung mit m:m Beziehungen. Meine Ext basieren auf 1:n wie Blog
> Example und dem Buch von Jochen Rau. Ich nehme an du hast drei
> Modelle: Event, Performance und Piece. Mir ist nicht klar wieso du
> nicht für die separate Seite im EventController eine eigene Action
> erstellen kannst (mit switchableControllerActions). Ich denke etwa so:
>
> $performances = iterator_to_array($this->eventRepository->FindAll());
> foreach ($performances as $performance)
> $pieces =
> iterator_to_array($this->performanceRepository->getPices($performace));
> foreach ($pieces as $piece)
> $allPieces[] = array('title' => $piece['title'], ...);
>
> Das ist nur eine Idee. Habs nicht getestet. Weiss nicht ob
> iterator_to_array() nötig ist. Im groupedForViewHelper ist sie noch, im
> forViewHelper nicht mehr. Übrigens sind die ViewHelper nützliche
> Vorlagen für PHP mit Objekten. Meine schreibe ich wenns in Fluid zu
> komplizert oder unmöglich ist. Das Ergebnis meiner Codeschnipsel
> kannst du bei http://ga.thomasnu.ch/index.php?id=89 anschauen. Da
> diese Agenda nicht mehr aktiv ist fehlen die Links bei den Tagen.
>
> Liebe Grüsse. Thomas
>
> Am 08.09.2013 10:35, schrieb Robert Wildling:
>> Hallo, Thomas,
>>
>> Danke für's Teilen deines Code-Snippets! Definitiv etwas, das ich mir
>> merken werde! Welche ViewHelper verwendest du da? Eigene?
>>
>> Im deinem Beispiel allerdings wird nicht ein Objekt in ein Array
>> verwandelt, wenn ich das richtig erkenne. Zusätzlich wäre es mir
>> wichtig, dass sich diese Arbeitsschritte alle im Model (oder Repository?
>> wo ist's besser?) befinden, weil ich keinen extra Controller anwerfen
>> kann (zuviele andere Daten, Zerstückelung der View).
>>
>> So eine Anforderung hast du wohl nicht zufällig auch schon mal gehabt??
>>
>> Jedenfalls danke! Dein Snippet schau ich mir mal ganz unäbhängig davon
>> an. (Kannst du mir vielleicht noch etwas zu den ViewHelpern verraten?
>> Was macht tnu:calendarDay? Das Attribut "add"?)
>>
>> Beste Grüße!
>> Robert
>>
>>> Hi Robert
>>>
>>> Für einen Kalender baute ich ein Array $weeks auf, das als Extbase
>>> Objekt verwendet werden kann:
>>>
>>> Controller:
>>> $weeks = array();
>>> for ($i = 0; $i < 3; $i++) {
>>> $m = $month + $i;
>>> if ($m > 12) {
>>> $m -= 12;
>>> if ($y == $year) $y++;
>>> }
>>> $first = mktime(0, 0, 0, $m, 1, $y);
>>> $w = date('w', $first);
>>> $monday = $first - 86400 * (($w == 0) ? 6 : $w - 1);
>>> while (date('Ym', $monday) <= 100 * $y + $m) {
>>> $weeks[] = array('monday' => $monday, 'month' => $m, 'first'
>>> => $first);
>>> $monday += 7 * 86400;
>>> }
>>> }
>>> $this->view->assign('weeks', $weeks);
>>>
>>> View:
>>> <f:groupedFor each="{weeks}" as="weekOfThisFirst" groupBy="first"
>>> groupKey="first">
>>> <tr>
>>> <td width="160" align="right" bgcolor="#FFDDBB"
>>> colspan="8"><b><tnu:term format="M Y">{first}</tnu:term></b></td>
>>> </tr>
>>> <f:for each="{weekOfThisFirst}" as="week" iteration="iter">
>>> <f:if condition="{iter.isFirst}">
>>> <tr>
>>> <td width="13" class="mini" bgcolor="#EEEECC"> </td>
>>> <f:for each="{0:0, 1:1, 2:2, 3:3, 4:4, 5:5, 6:6}" as="wday">
>>> <td width="21" class="mini" align="right"
>>> bgcolor="#EEEECC"><font color="#800000">
>>> <tnu:term format="D2"><tnu:calendarDay
>>> add="{wday}">{week.monday}</tnu:calendarDay></tnu:term></font></td>
>>> </f:for>
>>> </tr>
>>> </f:if>
>>> <tr>
>>> <td width="13" align="right" class="mini"
>>> bgcolor="#EEEECC"><font color="#800000"><tnu:term
>>> format="W">{week.monday}</tnu:term></font></td>
>>> <tnu:calendarDay add="0" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="1" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="2"
>>> month="{week.$this->productRepository->FindAll()month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="3" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="4" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="5" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> <tnu:calendarDay add="6" month="{week.month}"
>>> links="{dayLinks}">{week.monday}</tnu:calendarDay>
>>> </tr>
>>> </f:for>
>>> </f:groupedFor>
>>>
>>> Ich hoffe du hast mit diesen Ausschnitten einige Anregungen für die
>>> Lösung deines Problems.
>>>
>>> LG Thomas
>>>
>>>
>>> Am 07.09.2013 19:22, schrieb Robert Wildling:
>>>> Hi, liebe ExtbaselerInnen,
>>>>
>>>> In meiner kleinen Event-Extension sieht es so aus, dass innerhalb
>>>> eines
>>>> Events (zB ein Theaterfestival) mehrere Veranstaltungen (theatre
>>>> perfomances) sein können. Jede Performance wiederum kann aus einer
>>>> Aneinanderreihung einzelner kleiner Stücke bestehen. Das ganze ist mit
>>>> m:m-Realtionen gelöst:
>>>>
>>>> Event <-m:m-> Performaces <-m:m-> Pieces
>>>>
>>>> Schematische Darstellung des gewünschten Zielergebnisses:
>>>>
>>>> Event
>>>> - Performance 2
>>>> -- piece 1
>>>> -- piece 2
>>>> -- piece 3
>>>> - Performance 2
>>>> -- piece 1
>>>> -- piece 2
>>>> -- piece 3
>>>>
>>>> Nun sollen auf einer separaten Seite *alle* "pieces" angezeigt werden,
>>>> möglichst in alphabetischer Reigenfolge (die Performances sollen
>>>> *nicht*
>>>> angezeigt werden):
>>>>
>>>> Event
>>>> - piece 1
>>>> - piece 2
>>>> - piece 3
>>>> - piece 4
>>>> - piece 5
>>>> - piece 6
>>>>
>>>> Dazu versuche ich nun, im Event-Model eine Methode einzubauen, die
>>>> getPieces heißt und die aus allen zu diesem Event gehörnenden
>>>> Performaces alle Stücke lesen und sortieren soll. Da häng ich jetzt
>>>> aber: denn soweit ich weiß, muss das Objekt zunächst mal in ein Array
>>>> umgewandelt, dann durch die Array-Funktionen geschickt und schließlich
>>>> wieder in ein Objekt umgewandelt werden. Ich weiß nicht, wie das in
>>>> Extbase 6.1 gehen soll. Bisher habe ich nur das - die Kommentare
>>>> beschreiben meine Probleme:
>>>>
>>>> class Events extends \TYPO3\CMS\Extbase\DomainObject\AbstractEntity {
>>>> /**
>>>> * Performances that take place within this event
>>>> * @var
>>>> \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\Rowild\Theaterevents\Domain\Model\Performances>
>>>>
>>>>
>>>>
>>>> */
>>>> protected $performances;
>>>>
>>>> /**
>>>> * pieces: get all the pieces from all the performances
>>>> * @var
>>>> \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\Rowild\Theaterevents\Domain\Model\Pieces>
>>>>
>>>>
>>>>
>>>> */
>>>> protected $pieces;
>>>>
>>>> [...]
>>>> protected function initStorageObjects() {
>>>> $this->performaces = new
>>>> \TYPO3\CMS\Extbase\Persistence\ObjectStorage();
>>>> // muss hier für pieces noch ein eigenes storage initiiert
>>>> werden??
>>>> }
>>>>
>>>> /**
>>>> * Returns the performaces
>>>> * @return
>>>> \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\Rowild\Theaterevents\Domain\Model\Concerts>
>>>>
>>>>
>>>> $performacesafter
>>>> */
>>>> public function getPerformaces() {
>>>> return $this->performaces;
>>>> }
>>>>
>>>> /**
>>>> * Returns the pieces
>>>> *
>>>> * @ return
>>>> \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\Rowild\Theaterevents\Domain\Model\Compositions>
>>>>
>>>>
>>>> $premieres
>>>> */
>>>> public function getPieces() {
>>>> $pieces = $this->getPieces();
>>>> // $pieces = $this->getPieces()->toArray(); // ? toArray
>>>> scheint
>>>> es nicht mehr zu geben in Extbase 6.*
>>>>
>>>> foreach ($pieces as $piece) {
>>>> var_dump(get_object_vars($piece)); // spuckt nichts aus
>>>> $array[] = json_decode(json_encode($piece), true); //
>>>> detto
>>>>
>>>> //$ua[] = $this['pieces']['title']; // das ist der
>>>> Array-Ansatz, der bei Objekten aber nicht funktioniert
>>>> // TODO: Doppelte entfernen.
>>>> }
>>>> //print_r($array);
>>>> return $pieces;
>>>> }
>>>> }
>>>>
>>>>
>>>> Wie muss ich denn diese Funktion getPieces gestalten, um zunöchst ein
>>>> Array und dann wieder ein Objekt zu bekommen?
>>>> Ich bitte um Tipps, Links, etc!
>>>>
>>>> Vielen Dank!
>>>> Beste Grüße
>>>> Robert
>>>
>>
>
More information about the TYPO3-german
mailing list