Fixed validation errors
[dylansserver.git] / index.php
index 29e4076..f151a74 100644 (file)
--- a/index.php
+++ b/index.php
@@ -22,6 +22,8 @@ abstract class cms {
   public static function determine_type() {
     if (isset($_GET['page']) && is_numeric($_GET['page'])) {
          return 'page';
+       } else if (isset($_GET['year'])) {
+         return 'archive';
        } else if (isset($_GET['note'])) {
          return 'note';
        } else if ($_SERVER['REQUEST_URI'] == '/') {
@@ -61,7 +63,7 @@ abstract class cms {
     $scripts = "";
        $stylesheets = "<link href=\"/includes/style.css\" rel=\"stylesheet\" type=\"text/css\">";
        if (cms::determine_type() == "index") {
-         $scripts = "<script type=\"text/javascript\" src=\"/includes/all.js\">";
+         $scripts = "<script type=\"text/javascript\" src=\"/includes/all.js\"></script>"; 
          $home_link = "http://validator.w3.org/unicorn/check?ucn_uri=dylanstestserver.com&amp;ucn_task=conformance#";
        }
   echo <<<END_OF_HEAD
@@ -78,7 +80,6 @@ abstract class cms {
   <link rel="icon" href="favicon.ico" type="image/png">
   $stylesheets
   $scripts
-</script>
 </head>
 
 <body>
@@ -121,11 +122,11 @@ END_OF_CLOSE;
 
 class index extends cms {
        public function display() {
-               $this->display_head();
-               $this->display_exhibits();
-               echo "<ul id=\"portfolio\" style=\"text-align:right\">";
-               $this->list_projects();
-               echo <<<OTHER_PROJECTS
+         $this->display_head();
+         $this->display_exhibits();
+         echo "<ul id=\"portfolio\" style=\"text-align:right\">";
+         $this->list_projects();
+         echo <<<OTHER_PROJECTS
         <li>
           <h3>things i've done for others:</h3>
         </li>
@@ -160,12 +161,14 @@ class index extends cms {
         <li>
         </li>
 OTHER_PROJECTS;
-        // Because of the CSS necessary for the animations,
-               // the contact link needs to be in #portfolio to clear
-               // the floats.
-           $this->display_contact();
+      // Because of the CSS necessary for the animations,
+         // the contact link needs to be in #portfolio to clear
+         // the floats.
+      echo "<li>";
+         $this->display_contact();
+      echo "</li>";
       echo "</ul>";
-               $this->display_close($show_contact = false);
+         $this->display_close($show_contact = false);
        }
 
        protected function display_exhibits() {
@@ -179,7 +182,6 @@ OTHER_PROJECTS;
        }
 
        private function list_projects() {
-         echo "<div id=\"exhibit\">";
          echo <<<HEREDOC
         <li>
           <h3>my projects:</h3>
@@ -329,6 +331,92 @@ class note extends cms {
   }
 }
 
+
+class archive extends cms {
+
+  public function __construct() {
+    parent::__construct();
+  }
+
+  private function check_exists() {
+    $sql = "SELECT COUNT(*) FROM notes
+                         WHERE url = ?";
+       $results = $this->query($sql, "s", $_GET['note']);
+       if ($results[0]["COUNT(*)"] != 1) {
+         $this->not_found();
+       }
+  }
+
+  public function display() {
+    // this really needs its own pagination...
+       // there should be a class for that.
+       $this->display_head();
+       switch (true) {
+         case (isset($_GET['year']) && !isset($_GET['month'])
+                         && !isset($_GET['day'])):
+       $sql = "SELECT title, url, date_posted, text
+                               FROM notes WHERE YEAR(date_posted) = ?
+                               ORDER BY date_posted DESC";
+               $result = $this->query($sql, "d",
+                                                               $_GET['year']);
+           break;
+         case (isset($_GET['year']) && isset($_GET['month'])
+                         && !isset($_GET['day'])):
+       $sql = "SELECT title, url, date_posted, text
+                               FROM notes WHERE YEAR(date_posted) = ?
+                               AND MONTH(date_posted) = ?
+                               ORDER BY date_posted DESC";
+               $result = $this->query($sql, "dd",
+                                                               $_GET['year'], $_GET['month']);
+           break;
+         case (isset($_GET['year']) && isset($_GET['month'])
+                 && isset($_GET['day'])):
+       $sql = "SELECT title, url, date_posted, text
+                               FROM notes WHERE YEAR(date_posted) = ?
+                               AND MONTH(date_posted) = ?
+                               AND DAY(date_posted) = ?
+                               ORDER BY date_posted DESC";
+               $result = $this->query($sql, "ddd",
+                                                               $_GET['year'], $_GET['month'],
+                                                               $_GET['day']);
+           break;
+       }
+       if (count($result) >= 1) {
+         echo "<div id=\"notes\">";
+         foreach ($result as $row => $entry) {
+           $title = $entry['title'];
+           $url = '/note/' . $entry['url'];
+           $date_posted =  explode("-", $entry['date_posted']);
+           $year_posted = $date_posted[0];
+           $month_posted = $date_posted[1];
+           $datetime_posted = explode(' ', $date_posted[2]);
+           $day_posted = $datetime_posted[0];
+           echo "<div class=\"note\">";
+        echo "<h2><span style=\"color:grey;\">$year_posted/$month_posted/$day_posted/</span><a href=\"$url\">$title</a></h2>";
+           echo $entry['text'];
+           echo "</div>";
+         }
+         echo "</div>";
+         $this->write_navigation();
+       } else {
+         echo "<br>";
+         echo "<h2 style=\"font-family:sans-serif;\">sorry, nothing here</h2>";
+         echo "<pre>Empty set (0.00 sec)</pre>";
+       }
+    $this->display_close();
+  }
+
+  private function write_navigation() {
+       echo "<br>";
+    echo "<div id=\"navigation\">";
+    echo "<h2>";
+       // fill me in!
+    echo "</h2>";
+    echo "</div>";
+  }
+}
+
+
 class notFound extends Exception {
        public function __construct() {
       header("HTTP/1.0 404 Not Found");
@@ -356,6 +444,10 @@ switch (cms::determine_type()) {
     $page = new page;
        $page->display();
        break;
+  case "archive":
+    $archive = new archive;
+       $archive->display();
+       break;
 }
 
 ?>