*/ class Comment { public $id = 0; public $category = ""; public $time = 0; public $user = 0; public $reply = 0; public $text = ""; public $upvotes = 0; public $downvotes = 0; private $replyCache = []; public function __construct($id = 0) { // Get comment data from the database $data = DB::table('comments') ->where('comment_id', $id) ->get(); // Check if anything was returned and assign data if ($data) { $data = $data[0]; $this->id = $data->comment_id; $this->category = $data->comment_category; $this->time = $data->comment_timestamp; $this->user = $data->comment_poster; $this->reply = $data->comment_reply_to; $this->text = $data->comment_text; $this->getVotes(); } } public function save() { // Create submission data, insert and update take the same format $data = [ 'comment_category' => $this->category, 'comment_timestamp' => $this->time, 'comment_poster' => $this->user, 'comment_reply_to' => $this->reply, 'comment_text' => $this->text, ]; // Update if id isn't 0 if ($this->id) { DB::table('comments') ->where('comment_id', $this->id) ->update($data); } else { $this->id = DB::table('comments') ->insertGetId($data); } } private function getVotes() { $votes = DB::table('comment_votes') ->where('vote_comment', $this->id) ->get(); foreach ($votes as $vote) { if ($vote->vote_state) { $upvotes += 1; } else { $downvotes += 1; } } } public function replies() { if (!$this->replyCache) { $commentIds = DB::table('comments') ->where('comment_reply_to', $this->id) ->get(['comment_id']); $commentIds = array_column($comments, 'comment_id'); foreach ($commentIds as $comment) { $this->replyCache[$comment] = new Comment($comment); } } return $this->replyCache; } public function userData() { return User::construct($this->user); } public function vote() { // can't be fucked to implement this right now } }