Diskuze: Komentáře a odpovědi výpis ke článku

Člen

Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
Ahoj, koukám na to a hned asi vidím problém.
ve funkci processComments() se neustále odkazuješ na sebe. Odkrokuj si co se stane když zavoláš funci proccesComments(1); Dle mě ta funkce jede stále dokola a nemůže přestat protože jí stále předáváš druhej parametr jako null a tím pádem se zavolá znova se stejným paremetrem a tak pořád dokola a dokola dokud nespadne, protože nemůžeš mít nekonečné pole.
No především ve funkci getComments provádíš tento kód:
if ($parent_id === null) { // pokud je to hlacní komentář zjistit pod-komentáře
$_comment['comments'] = $this->getComments($article_id, $parent_id);
}
$_comments[] = $_comment;
až za foreachem, takže ti do $_comments spadne jen poslední $_comment.
Teoreticky by tohle všechno mělo jít udělat přímo v pohledu. Pokud máš správně nastavený cizí klíč, stačí, když vezmeš hlavní komentáře, a na každý podkomentář rekurzivně zavoláš ->related
Ale já mám ty komentáře i odpovědi ve stejné tabulce... to nevadí?
Takže takto?
public function getComments($article_id, $parent_id = null, &$_comments = [])
{
$comments = $this->database->table(self::TABLE_COMMENTS)->where(self::COLUMN_COM_ARTICLE_ID, $article_id)->order('created_at')->fetchAll();
foreach ($comments->related('parent_id') as $comm) {
// zpracování komentáře
$_comment = [
'comment_id' => $comm->comment_id,
'user_id' => $comm->user_id,
'created_at' => $comm->created_at,
'content' => $comm->content,
];
/* if ($comm->parent_id !== null) {
$_comment['comments'] = $this->getComments($article_id, $comm->parent_id, $_comments);
}*/
$_comments[] = $_comment;
}
return $_comments; // vrátit komentáře
}
Vsechny ty komentare by meli mit v tabulce jeden sloupec s id toho clanku. A potom dalsi sloupec, ve kterem je id komentare, na ktery navazuji. Cili, z databaze seznam komentaru vytahnes jako jednu tabulku. Dal uz pak zalezi jen na tom, jak si je usporadas. To by melo byt soucasti sql prikazu. Ale klidne to muzes delat az v php nebo v js.
Stejne, nejlepsi system je mit komentare serazene podle data a pridat tam
link, na ktery komentar to navazuje. Jako, muj nazor z pohledu ctenare. Podle
kontextu obvykle dokazi i bez jmena si tipnout k cemu je to reakce. Ale kdyz
nekdo zareaguje uprostred text, to si nevsimnes.
Jako, stromova struktura je pekna. Ale kdyz to jde, prepinam na serazeni podle
datumu.
Nějak takto si to myslel? Ale nefunguje to úplně jak bych chtěl...
public function getComments($article_id){
$comments = $this->database->table(self::TABLE_COMMENTS)->where(self::COLUMN_COM_ARTICLE_ID, $article_id)->order('created_at')->fetchAll();
foreach ($comments as $comment) {
// zpracování komentáře
$_comments = [
'comment_id' => $comment->comment_id,
'user_id' => $comment->user_id,
'created_at' => $comment->created_at,
'content' => $comment->content,
];
foreach ($comment->related('comments.parent_id') as $com) {
$_comment['comments'] = [
'comment_id' => $com->comment_id,
'user_id' => $com->user_id,
'created_at' => $com->created_at,
'content' => $com->content,
];
}
}
$_comments[] = $_comment;
return $_comments; // vrátit komentáře
}
Defakto ano, jen s tím rozdílem, že to budeš muset rekurzivně zanořit (pokud chceš mít neomezeně úrovní). A můžeš to dělat rovnou v lattečku.
Zobrazeno 9 zpráv z 9.