]> git.mjollnir.org Git - moodle.git/commitdiff
Workshop now supports calendar events for the deadline date
authormoodler <moodler>
Fri, 21 May 2004 13:20:36 +0000 (13:20 +0000)
committermoodler <moodler>
Fri, 21 May 2004 13:20:36 +0000 (13:20 +0000)
mod/workshop/db/mysql.php
mod/workshop/db/postgres7.php
mod/workshop/lib.php
mod/workshop/version.php

index 44c35dfefaf1a52e5c6340b653a9ec8af4558d36..b1d5bcc50e3dfab0f29e18d52f0defed956774b0 100644 (file)
@@ -75,6 +75,12 @@ function workshop_upgrade($oldversion) {
                 NOT NULL default '0' AFTER `resubmission`");
         execute_sql("ALTER TABLE `{$CFG->prefix}workshop_grades` ADD INDEX (`assessmentid`)");
     }
+
+    if ($oldversion < 2004052100) {
+        include_once("$CFG->dirroot/mod/workshop/lib.php");
+        workshop_refresh_events();
+    }
+
     
     return true;
 }
index 1a7de6c578cc9b092a009b55e913ed90b50c2c32..708aa4cca87be106310574254caea4281352bc1d 100644 (file)
@@ -18,12 +18,17 @@ function workshop_upgrade($oldversion) {
             assessmentid int8  NOT NULL default '0',
             userid int8 NOT NULL default '0',
             timecreated int8  NOT NULL default '0',
-           mailed int2  NOT NULL default '0',
+               mailed int2  NOT NULL default '0',
             comments text NOT NULL
         )
         ");
     }
     return true;
+
+    if ($oldversion < 2004052100) {
+        include_once("$CFG->dirroot/mod/workshop/lib.php");
+        workshop_refresh_events();
+    }
 }
 
 
index eea98f858307a7e7cdf99519ac8012ac8be969d2..32cf224b4ba8b3a9a55322cd6f44e604ef56dcff 100644 (file)
@@ -59,6 +59,7 @@ workshop_cron ()
 workshop_delete_instance($id) 
 workshop_grades($workshopid) 
 workshop_print_recent_activity(&$logs, $isteacher=false) 
+workshop_refresh_events($workshop) 
 workshop_update_instance($workshop) 
 workshop_user_complete($course, $user, $mod, $workshop) 
 workshop_user_outline($course, $user, $mod, $workshop) 
@@ -77,7 +78,24 @@ function workshop_add_instance($workshop) {
                        $workshop->deadlinemonth, $workshop->deadlineday, $workshop->deadlinehour, 
                        $workshop->deadlineminute);
 
-    return insert_record("workshop", $workshop);
+    if ($returnid = insert_record("workshop", $workshop)) {
+
+        $event = NULL;
+        $event->name        = $workshop->name;
+        $event->description = $workshop->description;
+        $event->courseid    = $workshop->course;
+        $event->groupid     = 0;
+        $event->userid      = 0;
+        $event->modulename  = 'workshop';
+        $event->instance    = $returnid;
+        $event->eventtype   = 'deadline';
+        $event->timestart   = $workshop->deadline;
+        $event->timeduration = 0;
+
+        add_event($event);
+    }
+
+    return $returnid;
 }
 
 
@@ -561,6 +579,10 @@ function workshop_delete_instance($id) {
         $result = false;
     }
 
+    if (! delete_records('event', 'modulename', 'workshop', 'instance', $workshop->id)) {
+        $result = false;    
+    }   
+
     return $result;
 }
 
@@ -806,6 +828,50 @@ function workshop_print_recent_activity($course, $isteacher, $timestart) {
 }
 
 
+///////////////////////////////////////////////////////////////////////////////
+function workshop_refresh_events($courseid = 0) {
+// This standard function will check all instances of this module
+// and make sure there are up-to-date events created for each of them.
+// If courseid = 0, then every workshop event in the site is checked, else
+// only workshop events belonging to the course specified are checked.
+// This function is used, in its new format, by restore_refresh_events()
+
+    if ($courseid == 0) {
+        if (! $workshops = get_records("workshop")) {
+            return true;        
+        }   
+    } else {
+        if (! $workshops = get_records("workshop", "course", $courseid)) {
+            return true;
+        }
+    }
+    $moduleid = get_field('modules', 'id', 'name', 'workshop');
+    
+    foreach ($workshops as $workshop) {
+        $event = NULL;
+        $event->name        = addslashes($workshop->name);
+        $event->description = addslashes($workshop->description);
+        $event->timestart   = $workshop->deadline;
+
+        if ($event->id = get_field('event', 'id', 'modulename', 'workshop', 'instance', $workshop->id)) {
+            update_event($event);
+    
+        } else {
+            $event->courseid    = $workshop->course;
+            $event->groupid     = 0;
+            $event->userid      = 0;
+            $event->modulename  = 'workshop';
+            $event->instance    = $workshop->id; 
+            $event->eventtype   = 'deadline';
+            $event->timeduration = 0;
+            $event->visible     = get_field('course_modules', 'visible', 'module', $moduleid, 'instance', $workshop->id); 
+            add_event($event);
+        }
+
+    }
+    return true;
+}   
+
 
 ///////////////////////////////////////////////////////////////////////////////
 function workshop_update_instance($workshop) {
@@ -821,7 +887,21 @@ function workshop_update_instance($workshop) {
 
     $workshop->id = $workshop->instance;
 
-    return update_record("workshop", $workshop);
+    if ($returnid = update_record("workshop", $workshop)) {
+
+        $event = NULL;
+
+        if ($event->id = get_field('event', 'id', 'modulename', 'workshop', 'instance', $workshop->id)) {
+
+            $event->name        = $workshop->name;
+            $event->description = $workshop->description;
+            $event->timestart   = $workshop->deadline;
+
+            update_event($event);
+        }
+    }
+
+    return $returnid;
 }
 
 
index 660a96ab37b5f1457f2eee677193c59c3ff63dca..0072334947d826bd176e96bf4639d2988ef982d3 100644 (file)
@@ -5,7 +5,7 @@
 //  This fragment is called by /admin/index.php
 ////////////////////////////////////////////////////////////////////////////////
 
-$module->version  = 2004013101;
+$module->version  = 2004052100;
 $module->requires = 2004013101;  // Requires this Moodle version
 $module->cron     = 60;