Display posts, not pics
authorJacob Casper <dev@jacobcasper.com>
Sat, 9 Apr 2022 21:17:08 +0000 (16:17 -0500)
committerJacob Casper <dev@jacobcasper.com>
Sat, 9 Apr 2022 21:17:08 +0000 (16:17 -0500)
Now that we have posts, pics, and comments, rework content display to be
focused on whole posts.

index.php

index a33a56cabe77a50045957e90ee53783644958528..804a15e605e878548de8302a19a2f03fe2813561 100644 (file)
--- a/index.php
+++ b/index.php
@@ -5,15 +5,29 @@
 require_once __DIR__ . '/db.php';
 
 $db = get_db();
-$pics = $db->query('SELECT * from pics');
-while ($pic = $pics->fetchArray()) {
-  $mime_type = $pic['MIME_TYPE'];
-  $file_b64 = $pic['PIC_B64'];
-  $name = $pic['ID'];
+$posts = $db->query('SELECT
+  p.ID, p.TIMESTAMP, pi.MIME_TYPE, pi.PIC_B64, c.BODY
+  FROM posts p
+  JOIN pics pi on p.id = pi.post_id
+  JOIN comments c on p.id = c.post_id
+  ORDER BY p.TIMESTAMP DESC');
+while ($post = $posts->fetchArray()) {
+  $mime_type = $post['MIME_TYPE'];
+  $file_b64 = $post['PIC_B64'];
+  $post_id = $post['ID'];
+  $comment_text = $post['BODY'];
+  $img = new Imagick();
+  $img->readImageBlob(base64_decode($file_b64));
+  $img->setImageCompressionQuality(85);
+  $img->adaptiveResizeImage(480, 0);
+  $compressed_b64 = base64_encode($img->getImageBlob());
 
-  echo "<img src='data:{$mime_type};base64,{$file_b64}' alt='$name'/>";
+  echo "<div id='post-{$post_id}'>";
+
+  echo "<img src='data:{$mime_type};base64,{$compressed_b64}' alt='$'/>";
+  echo "<p>{$comment_text}</p>";
+  echo '</div>';
 }
-echo '<p>done with pics</p>';
 ?>
 <div>footer</div>
 </html>