Skip to content
archive.module 7.53 KiB
Newer Older
Dries Buytaert's avatar
Dries Buytaert committed
<?php
// $Id$

function archive_system($field){
Dries Buytaert's avatar
 
Dries Buytaert committed
  $system["description"] = t("Displays a calendar to navigate old content.");
Dries Buytaert's avatar
 
Dries Buytaert committed
  $system["admin_help"] = t("Choose the starting \"day of the week\" for the displayed calendar block.");
Dries Buytaert's avatar
 
Dries Buytaert committed
function archive_calendar($original = 0) {
Dries Buytaert's avatar
 
Dries Buytaert committed
  global $user;
Dries Buytaert's avatar
 
Dries Buytaert committed
  $edit = $_POST["edit"];
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  // Extract today's date:
Dries Buytaert's avatar
 
Dries Buytaert committed
  $offset = time() + $user->timezone;
  $start_of_today = mktime(0, 0, 0, date("n", $offset), date("d", $offset), date("Y", $offset)) + $user->timezone;
  $end_of_today = mktime(23, 59, 59, date("n", $offset), date("d", $offset), date("Y", $offset)) + $user->timezone;
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  // Extract the requested date:
Dries Buytaert's avatar
 
Dries Buytaert committed
  if ($edit["year"] && $edit["month"] && $edit["day"]) {
    $year = $edit["year"];
    $month = $edit["month"];
    $day = $edit["day"];

Dries Buytaert's avatar
 
Dries Buytaert committed
    $requested = mktime(0, 0, 0, $month, $day, $year) + $user->timezone;
Dries Buytaert's avatar
 
Dries Buytaert committed
  }
  else if (arg(0) == "archive" && arg(3)) {
Dries Buytaert's avatar
 
Dries Buytaert committed
    $year = arg(1);
    $month = arg(2);
    $day = arg(3);
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    $requested = mktime(0, 0, 0, $month, $day, $year) + $user->timezone;
Dries Buytaert's avatar
 
Dries Buytaert committed
  }
  else {
    $year = date("Y", time());
    $month  = date("n", time());
    $day = date("d", time());
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    $requested = $end_of_today + $user->timezone;
Dries Buytaert's avatar
 
Dries Buytaert committed
  }
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  $start_of_month = mktime(0, 0, 0, $month, 1, $year);

Dries Buytaert's avatar
Dries Buytaert committed
  // Extract first day of the month:
Dries Buytaert's avatar
 
Dries Buytaert committed
  $first = date("w", $start_of_month);
Dries Buytaert's avatar
Dries Buytaert committed

  // Extract last day of the month:
Dries Buytaert's avatar
 
Dries Buytaert committed
  $last = date("t", $start_of_month);

  $end_of_month = mktime(23,59,59, $month, $last, $year);

  $cache = cache_get("archive:calendar:$start_of_month");

  if (!empty($cache)) {
    return $cache->data;
  }
Dries Buytaert's avatar
Dries Buytaert committed

  // Calculate previous and next months dates and check for shorter months (28/30 days)
  $prevmonth = mktime(23, 59, 59, $month - 1, 1, $year);
  $prev = mktime(23, 59, 59, $month - 1, min(date("t", $prevmonth), $day), $year);
  $nextmonth = mktime(23, 59, 59, $month + 1, 1, $year);
  $next = mktime(23, 59, 59, $month + 1, min(date("t", $nextmonth), $day), $year);

Dries Buytaert's avatar
 
Dries Buytaert committed

  $result = db_query("SELECT created FROM node WHERE status = 1 AND created > $start_of_month AND created < $end_of_month");

  $days_with_posts = array();
  while ($day_with_post = db_fetch_object($result)) {
Dries Buytaert's avatar
 
Dries Buytaert committed
    $days_with_posts[] = date("j", $day_with_post->created + $user->timezone);
Dries Buytaert's avatar
 
Dries Buytaert committed
  }
  $days_with_posts = array_unique($days_with_posts);

Dries Buytaert's avatar
Dries Buytaert committed
  // Generate calendar header:
  $output .= "\n<!-- calendar -->\n";
Dries Buytaert's avatar
 
Dries Buytaert committed
  $output .= "<div class=\"calendar\">";
Dries Buytaert's avatar
 
Dries Buytaert committed
  $output .= "<table>\n";
Dries Buytaert's avatar
 
Dries Buytaert committed
  $output .= " <tr><td colspan=\"7\" class=\"header-month\">". l("&laquo;", "archive/". date("Y/m/d", $prev)) ." ". date("F Y", $requested) ." ". ($nextmonth <= time() ? l("&raquo;", "archive/". date("Y/m/d", $next)) : "&nbsp;") ."</td></tr>\n";
Dries Buytaert's avatar
 
Dries Buytaert committed

  // First day of week (0 => Sunday, 1 => Monday, ...)
  $weekstart = variable_get("default_firstday", 0);

  // Last day of week
  ($weekstart - 1 == -1 ) ? $lastday = 6 : $lastday = $weekstart - 1;
Dries Buytaert's avatar
Dries Buytaert committed

  // Generate the days of the week:
Dries Buytaert's avatar
 
Dries Buytaert committed
  $firstcolumn = mktime(0, 0, 0, 3, 20 + $weekstart, 1994);
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  $output .= " <tr class=\"header-week\">";
Dries Buytaert's avatar
Dries Buytaert committed
  for ($i = 0; $i < 7; $i++) {
    $output .= "<td>". t(substr(ucfirst(date("l", $firstcolumn + $i * 86400)), 0, 2)) ."</td>";
Dries Buytaert's avatar
Dries Buytaert committed
  }
  $output .= "</tr>\n";

  // Initialize temporary variables:
  $nday = 1;
  $sday = $first;

  // Loop through all the days of the month:
  while ($nday <= $last) {
    // Set up blank days for first week of the month:
Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($first != $weekstart) {
      $blankdays = ($first - $weekstart + 7) % 7;
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= " <tr class=\"row-week\"><td class=\"day-blank\" colspan=\"$blankdays\">&nbsp;</td>\n";
Dries Buytaert's avatar
 
Dries Buytaert committed
      $first = $weekstart;
Dries Buytaert's avatar
Dries Buytaert committed
    }
    // Start every week on a new line:
Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($sday == $weekstart) {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= " <tr class=\"row-week\">\n";
Dries Buytaert's avatar
Dries Buytaert committed
    }

    // Print one cell:
Dries Buytaert's avatar
 
Dries Buytaert committed
    $date = mktime(0, 0, 0, $month, $nday, $year) + $user->timezone;
Dries Buytaert's avatar
 
Dries Buytaert committed
    if (in_array($nday, $days_with_posts)) {
      $daytext = l($nday, "archive/$year/$month/$nday");
Dries Buytaert's avatar
 
Dries Buytaert committed
      $dayclass = "day-link";
Dries Buytaert's avatar
 
Dries Buytaert committed
    }
    else {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $daytext = "<div>$nday</div>";
Dries Buytaert's avatar
 
Dries Buytaert committed
      $dayclass = "day-normal";
Dries Buytaert's avatar
 
Dries Buytaert committed
    }
Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($date == $requested) {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= "  <td class=\"day-selected\">$daytext</td>\n";
Dries Buytaert's avatar
 
Dries Buytaert committed
    }
    else if ($date == $start_of_today) {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= "  <td class=\"day-today\">$daytext</td>\n";
Dries Buytaert's avatar
Dries Buytaert committed
    }
Dries Buytaert's avatar
 
Dries Buytaert committed
    else if ($date > $end_of_today) {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= "  <td class=\"day-future\">$daytext</td>\n";
Dries Buytaert's avatar
Dries Buytaert committed
    }
    else {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $output .= "  <td class=\"$dayclass\">$daytext</td>\n";
Dries Buytaert's avatar
Dries Buytaert committed
    }

    // Start every week on a new line:
Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($sday == $lastday) {
Dries Buytaert's avatar
Dries Buytaert committed
      $output .=  " </tr>\n";
    }

    // Update temporary variables:
    $sday++;
    $sday = $sday % 7;
    $nday++;
  }

  // Complete the calendar:
Dries Buytaert's avatar
 
Dries Buytaert committed
  if ($sday != $weekstart) {
    $end = (7 - $sday + $weekstart) % 7;
Dries Buytaert's avatar
 
Dries Buytaert committed
    $output .= "  <td class=\"day-blank\" colspan=\"$end\">&nbsp;</td>\n </tr>\n";
Dries Buytaert's avatar
Dries Buytaert committed
  }

Dries Buytaert's avatar
 
Dries Buytaert committed
  $output .= "</table></div>\n\n";
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  cache_set("archive:calendar:$first", $output, time() + variable_get("cache_clear", 120));

Dries Buytaert's avatar
Dries Buytaert committed
  return $output;
}

Dries Buytaert's avatar
 
Dries Buytaert committed
function archive_block($op = "list", $delta = 0) {
Dries Buytaert's avatar
Dries Buytaert committed
  global $date;
Dries Buytaert's avatar
 
Dries Buytaert committed
  if ($op == "list") {
    $blocks[0]["info"] = t("Calendar to browse archives");
    return $blocks;
  }
  else {
    switch ($delta) {
      case 0:
        $block["subject"] = t("Browse archives");
Dries Buytaert's avatar
 
Dries Buytaert committed
        $block["content"] = archive_calendar();
Dries Buytaert's avatar
 
Dries Buytaert committed
        return $block;
    }
  }
Dries Buytaert's avatar
Dries Buytaert committed
}

function archive_link($type) {
Dries Buytaert's avatar
 
Dries Buytaert committed

  $links = array();

Dries Buytaert's avatar
Dries Buytaert committed
  if ($type == "page" && user_access("access content")) {
Dries Buytaert's avatar
 
Dries Buytaert committed
    $links[] = l(t("archives"), "archive", array("title" => t("Read the older content in our archive.")));
Dries Buytaert's avatar
Dries Buytaert committed
  }

Dries Buytaert's avatar
 
Dries Buytaert committed
  return $links;
Dries Buytaert's avatar
Dries Buytaert committed
}

function archive_page() {
Dries Buytaert's avatar
 
Dries Buytaert committed
  global $date, $month, $year, $meta, $user;
Dries Buytaert's avatar
 
Dries Buytaert committed

  $op = $_POST["op"];
  $edit = $_POST["edit"];
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
  theme("header");
Dries Buytaert's avatar
Dries Buytaert committed

  if (user_access("access content")) {
Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($op == t("Show")) {
      $year = $edit["year"];
      $month = $edit["month"];
      $day = $edit["day"];
    }
    else {
      $year = arg(1);
      $month = arg(2);
      $day = arg(3);
    }
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    $date = mktime(0, 0, 0, $month, $day, $year) - $user->timezone;
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    /*
    ** Prepare the values of the form fields:
    */
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    $years = array(2000 => "2000", 2001 => "2001", 2002 => "2002", 2003 => "2003", 2004 => "2004", 2005 => "2005");
    $months = array(1 => t("January"), 2 => t("February"), 3 => t("March"), 4 => t("April"), 5 => t("May"), 6 => t("June"), 7 => t("July"), 8 => t("August"), 9 => t("September"), 10 => t("October"), 11 => t("November"), 12 => t("December"));
    for ($i = 1; $i <= 31; $i++) $days[$i] = $i;
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    $start = "<div class=\"container-inline\">";
Dries Buytaert's avatar
 
Dries Buytaert committed
    $start .= form_select("", "year", ($year ? $year : date("Y")), $years). form_select("", "month", ($month ? $month : date("m")), $months) . form_select("", "day", ($day ? $day : date("d")), $days) . form_submit(t("Show"));
    $start .= "</div>";
Dries Buytaert's avatar
 
Dries Buytaert committed
    theme("box", t("Archives"), form($start));
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    /*
    ** Fetch nodes for the selected date, or current date if none
    ** selected.
    */
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
    if ($year && $month && $day) {
Dries Buytaert's avatar
 
Dries Buytaert committed
      $result = db_query_range("SELECT nid FROM node WHERE status = '1' AND created > %d ORDER BY created", $date, 0, 20);
Dries Buytaert's avatar
Dries Buytaert committed

Dries Buytaert's avatar
 
Dries Buytaert committed
      while ($nid = db_fetch_object($result)) {
        node_view(node_load(array("nid" => $nid->nid)), 1);
Dries Buytaert's avatar
Dries Buytaert committed
      }
Dries Buytaert's avatar
 
Dries Buytaert committed
    }
Dries Buytaert's avatar
Dries Buytaert committed
  }
  else {
Dries Buytaert's avatar
 
Dries Buytaert committed
    message_access();
Dries Buytaert's avatar
Dries Buytaert committed
  }

Dries Buytaert's avatar
 
Dries Buytaert committed
  theme("footer");
Dries Buytaert's avatar
Dries Buytaert committed
}

Dries Buytaert's avatar
 
Dries Buytaert committed

  $output .= form_select( t("First day of week"), "default_firstday", variable_get("default_firstday", 0), array(0 => t("Sunday"), 1 => t("Monday"), 2 => t("Tuesday"), 3 => t("Wednesday"), 4 => t("Thursday"), 5 => t("Friday"), 6 => t("Saturday")), t("The first day of the week.  By changing this value you choose how the calendar block is rendered."));

  return $output;
}

?>