Difference between revisions of "Extension:SimpleCalendar"

From Organic Design wiki
(New named parameter version from MW:Extension:Simple Calendar)
m ({{Category:Extensions}})
Line 1: Line 1:
 
<?php
 
<?php
# MediaWiki Simple Calendar Extension {{#Security:*|dev}}{{#Security:view|*}}{{php}}
+
# MediaWiki Simple Calendar Extension {{#Security:*|dev}}{{#Security:view|*}}{{php}}{{Category:Extensions}}
 
# - Version 1.00 (2007-04-24)
 
# - Version 1.00 (2007-04-24)
 
# - See http://www.mediawiki.org/wiki/Extension:Simple_Calendar for installation and usage details
 
# - See http://www.mediawiki.org/wiki/Extension:Simple_Calendar for installation and usage details

Revision as of 23:48, 5 May 2007

<?php

  1. MediaWiki Simple Calendar Extension {{#Security:*|dev}}{{#Security:view|*}}Template:Php
Info.svg These are the MediaWiki extensions we're using and/or developing. Please refer to the information on the mediawiki.org wiki for installation and usage details. Extensions here which have no corresponding mediawiki article are either not ready for use or have been superseded. You can also browse our extension code in our local Subversion repository or our GitHub mirror.
  1. - Version 1.00 (2007-04-24)
  2. - See http://www.mediawiki.org/wiki/Extension:Simple_Calendar for installation and usage details
  3. - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html)
  4. - Author: http://www.organicdesign.co.nz/nad

$wgExtensionFunctions[] = 'wfSetupSimpleCalendar'; $wgHooks['LanguageGetMagic'][] = 'wfCalendarLanguageGetMagic'; function wfCalendarLanguageGetMagic(&$magicWords,$langCode = 0) {

       $magicWords['calendar'] = array(0,'calendar');
       return true;
       }

function wfSetupSimpleCalendar() {

       global $wgParser;
       $wgParser->setFunctionHook('calendar','wfRenderCalendar');
       return true;
       }
  1. Renders a table of all the individual month tables

function wfRenderCalendar(&$parser) {

       $argv = array();
       foreach (func_get_args() as $arg) if (!is_object($arg)) {
               if (preg_match('/^(.+?)\\s*=\\s*(.+)$/',$arg,$match)) $argv[$match[1]]=$match[2];
               }
       if (isset($argv['title'])) $p = $argv['title'].'/'; else $p = ;
       if (isset($argv['query'])) $q = $argv['query'].'&action=edit'; else $q = 'action=edit';
       if (isset($argv['year']))  $y = $argv['year']; else $y = date('Y');
       if (isset($argv['month'])) {
               $m = $argv['month'];
               return wfRenderMonth(strftime('%m',strtotime("$y-$m-01")),$y,$p,$q);
               } else $m = 1;
       $table = "{| class=\"calendar\"\n";
       for ($rows = 3; $rows--; $table .= "|-\n")
               for ($cols = 0; $cols < 4; $cols++)
                       $table .= '|'.wfRenderMonth($m++,$y,$p,$q)."\n";
       return "$table\n|}\n";
       }
  1. Return a calendar table of the passed month and year

function wfRenderMonth($m,$y,$prefix = ,$query = ) {

       $thisDay   = date('d');
       $thisMonth = date('n');
       $thisYear  = date('Y');
       if (!$d = date('w',$ts = mktime(1,1,1,$m,1,$y))) $d = 7;
       $month = strftime('%B',$ts);
       $table = "\n{| class=\"month\"\n|- class=\"heading\"\n|colspan=\"7\"|$month\n|- class=\"dow\"\n";
       $table .= "|M||T||W||T||F||S||S\n";
       if ($d > 1) $table .= "|-".str_repeat("\n| \n",$d-1);
       for ($i = $day = $d; $day < 32; $i++) {
               $day = $i - $d + 1;
               $dd = $day < 10 ? "0$day" : $day;
               if ($day < 29 or checkdate($m,$day,$y)) {
                       if ($i%7 == 1) $table .= "\n|-\n";
                       $t = ($day == $thisDay and $m == $thisMonth and $y == $thisYear) ? ' class="today"' : ;
                       $ttext = "$prefix$dd $month $y";
                       $title = Title::newFromText($ttext);
                       $class = $title->exists() ? 'day-active' : 'day-empty';
                       $url = $title->getFullURL($title->exists() ?  : $query);
                       $table .= "|$t|[$url $day]\n";
                       }
               }
       return "$table\n|}";
       }

?>