You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							283 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							283 lines
						
					
					
						
							13 KiB
						
					
					
				| <?PHP // $Id: sessions.php,v 1.2.2.3 2009/02/23 19:22:41 dlnsk Exp $ | |
|  | |
|     require_once('../../config.php');     | |
| 	require_once($CFG->libdir.'/blocklib.php'); | |
| 	require_once('locallib.php');	 | |
| 	require_once('lib.php'); | |
| 	require_once('add_form.php'); | |
| 	require_once('update_form.php'); | |
| 	require_once('duration_form.php'); | |
| 	 | |
|     if (!function_exists('grade_update')) { //workaround for buggy PHP versions | |
|         require_once($CFG->libdir.'/gradelib.php'); | |
|     } | |
|      | |
|     $id   	= required_param('id', PARAM_INT); | |
|     $action = required_param('action', PARAM_ACTION); | |
|      | |
|     if ($id) { | |
|         if (! $cm = get_record('course_modules', 'id', $id)) { | |
|             error('Course Module ID was incorrect'); | |
|         } | |
|         if (! $course = get_record('course', 'id', $cm->course)) { | |
|             error('Course is misconfigured'); | |
|         } | |
| 	    if (! $attforblock = get_record('attforblock', 'id', $cm->instance)) { | |
| 	        error("Course module is incorrect"); | |
| 	    } | |
|     } | |
| 
 | |
|     require_login($course->id); | |
| 
 | |
|     if (! $user = get_record('user', 'id', $USER->id) ) { | |
|         error("No such user in this course"); | |
|     } | |
|      | |
|     if (!$context = get_context_instance(CONTEXT_MODULE, $cm->id)) { | |
|         print_error('badcontext'); | |
|     } | |
|      | |
|     require_capability('mod/attforblock:manageattendances', $context); | |
| 
 | |
|     $navlinks[] = array('name' => $attforblock->name, 'link' => "view.php?id=$id", 'type' => 'activity'); | |
|     $navlinks[] = array('name' => get_string($action, 'attforblock'), 'link' => null, 'type' => 'activityinstance'); | |
|     $navigation = build_navigation($navlinks); | |
|     print_header("$course->shortname: ".$attforblock->name.' - '.get_string($action,'attforblock'), $course->fullname, | |
|                  $navigation, "", "", true, " ", navmenu($course)); | |
| 
 | |
| 	////////////////////////////////////////////////////////// | |
| 	// Adding sessions | |
| 	////////////////////////////////////////////////////////// | |
| 	     | |
| 	if ($action === 'add') { | |
| 		 | |
| 		show_tabs($cm, $context, 'add'); | |
| 		$mform_add = new mod_attforblock_add_form('sessions.php', array('course'=>$course, 'cm'=>$cm, 'modcontext'=>$context)); | |
| 	     | |
| 	    if ($fromform = $mform_add->get_data()) { | |
| 			$duration = $fromform->durtime['hours']*HOURSECS + $fromform->durtime['minutes']*MINSECS; | |
| 			$now = time(); | |
| 			 | |
| 	    	if (isset($fromform->addmultiply)) { | |
| 		    	$startdate = $fromform->sessiondate;// + $fromform->stime['hour']*3600 + $fromform->stime['minute']*60; | |
| 				$enddate = $fromform->sessionenddate + ONE_DAY; // because enddate in 0:0am | |
| 				 | |
| 				//get number of days | |
| 				$days = (int)ceil(($enddate - $startdate) / ONE_DAY); | |
| 				if($days <= 0) | |
| 					error(get_string('wrongdatesselected','attforblock'), "sessions.php?id=$id&action=add"); | |
| 				else { | |
| 					add_to_log($course->id, 'attendance', 'multiply sessions added', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
| 		 | |
| 					// Getting first day of week | |
| 					$sdate = $startdate; | |
| 					$dinfo = usergetdate($sdate); | |
| 					if ($CFG->calendar_startwday === '0') { //week start from sunday | |
| 						$startweek = $startdate - $dinfo['wday'] * ONE_DAY; //call new variable | |
| 					} else { | |
| 						$wday = $dinfo['wday'] === 0 ? 7 : $dinfo['wday']; | |
| 						$startweek = $startdate - ($wday-1) * ONE_DAY; | |
| 					} | |
| 					// Adding sessions | |
| 					$wdaydesc = array(0=>'Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'); | |
| 					while ($sdate < $enddate) { | |
| 						if($sdate < $startweek + ONE_WEEK) { | |
| 							$dinfo = usergetdate($sdate); | |
| 							if(key_exists($wdaydesc[$dinfo['wday']] ,$fromform->sdays)) { | |
| 								//check whether this date there is in our session days | |
| //								if(count_records('attendance_sessions', 'courseid', $course->id, 'sessdate', $sdate) > 0) { | |
| //									notify(strftime(get_string('strftimedmy', 'attforblock'), $sdate).': '.get_string('sessionexist','attforblock')); | |
| //									$sdate += ONE_DAY; | |
| //									continue; | |
| //								} | |
| 								$rec->courseid = $course->id; | |
| 								$rec->sessdate = $sdate; | |
| 								$rec->duration = $duration; | |
| 								$rec->description = $fromform->sdescription; | |
| 								$rec->timemodified = $now; | |
|                                 if ($fromform->sessiontype == COMMONSESSION) { | |
|                                     if(!insert_record('attendance_sessions', $rec)) | |
|                                         error(get_string('erroringeneratingsessions','attforblock'), "sessions.php?id=$id&action=add"); | |
|                                 } else { | |
|                                     foreach ($fromform->groups as $groupid) { | |
|                                         $rec->groupid = $groupid; | |
|                                         if(!insert_record('attendance_sessions', $rec)) | |
|                                             error(get_string('erroringeneratingsessions','attforblock'), "sessions.php?id=$id&action=add"); | |
|                                     } | |
|                                 } | |
| 							} | |
| 							$sdate += ONE_DAY; | |
| 						} else { | |
| 							$startweek += ONE_WEEK * $fromform->period; | |
| 							$sdate = $startweek; | |
| 						} | |
| 					} | |
| 					notice(get_string('sessionsgenerated','attforblock')); | |
| 				}	    		 | |
| 	    	} else { | |
| 				// insert one session | |
| 				$rec->courseid = $course->id; | |
| 				$rec->sessdate = $fromform->sessiondate; | |
| 				$rec->duration = $duration; | |
| 				$rec->description = $fromform->sdescription; | |
| 				$rec->timemodified = $now; | |
|                 if ($fromform->sessiontype == COMMONSESSION) { | |
|                     if(insert_record('attendance_sessions', $rec)) { | |
|                         add_to_log($course->id, 'attendance', 'one session added', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
|                         notice(get_string('sessionadded','attforblock')); | |
|                     } else | |
|                         error(get_string('errorinaddingsession','attforblock'), "sessions.php?id=$id&action=add"); | |
|                 } else { | |
|                     foreach ($fromform->groups as $groupid) { | |
|                         $rec->groupid = $groupid; | |
|                         if(!insert_record('attendance_sessions', $rec)) | |
|                             error(get_string('errorinaddingsession','attforblock'), "sessions.php?id=$id&action=add"); | |
|                     } | |
|                     add_to_log($course->id, 'attendance', 'one session added', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
|                     notice(get_string('sessionadded','attforblock')); | |
|                 } | |
| 	    	} | |
| 	    } | |
| 		$mform_add->display(); | |
| 	} | |
| 	 | |
| 	////////////////////////////////////////////////////////// | |
| 	// Updating sessions | |
| 	////////////////////////////////////////////////////////// | |
|  | |
| 	if ($action === 'update') { | |
| 		 | |
| 		$sessionid	= required_param('sessionid'); | |
| 		$mform_update = new mod_attforblock_update_form('sessions.php', array('course'=>$course,  | |
| 																			  'cm'=>$cm,  | |
| 																			  'modcontext'=>$context, | |
| 																			  'sessionid'=>$sessionid)); | |
| 	    if ($mform_update->is_cancelled()) { | |
| 	    	redirect('manage.php?id='.$id); | |
| 	    } | |
| 	    if ($fromform = $mform_update->get_data()) { | |
| 		    if (!$att = get_record('attendance_sessions', 'id', $sessionid) ) { | |
| 		        error('No such session in this course'); | |
| 		    } | |
| 		 | |
| //			$newdate = mktime($newhour, $newminute, 0, $newmonth, $newday, $newyear); //new variables called here | |
| 		 | |
| 			//check for duplicate | |
| //			$count = count_records('attendance_sessions','courseid', $course->id, 'sessdate', $newdate); | |
| //			if($count != 0 && $newdate != $att->sessdate)		//duplicate session exists | |
| //			    error(get_string('sessionalreadyexists','attforblock'),"sessions.php?id=".$id."&sessionid=". | |
| //		            $sessionid."&sessdate=".$att->sessdate."&action=update");	 | |
| //			else | |
| //			{	 | |
| 				//update session | |
| 				$att->sessdate = $fromform->sessiondate; | |
| 				$att->duration = $fromform->durtime['hours']*HOURSECS + $fromform->durtime['minutes']*MINSECS; | |
| 				$att->description = $fromform->sdescription; | |
| 				$att->timemodified = time(); | |
| 				update_record('attendance_sessions', $att); | |
| 				add_to_log($course->id, 'attendance', 'Session updated', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
| 				//notice(get_string('sessionupdated','attforblock'), 'manage.php?id='.$id); | |
| 				redirect('manage.php?id='.$id, get_string('sessionupdated','attforblock'), 3); | |
| //			} | |
| 		} | |
| 	 | |
| 		print_heading(get_string('update','attforblock').' ' .get_string('attendanceforthecourse','attforblock').' :: ' .$course->fullname); | |
| 		$mform_update->display(); | |
| 	} | |
| 	 | |
| 	////////////////////////////////////////////////////////// | |
| 	// Deleting sessions | |
| 	////////////////////////////////////////////////////////// | |
|  | |
| 	if ($action === 'delete') { | |
| 		$sessionid	 = required_param('sessionid'); | |
| 		$confirm = optional_param('confirm'); | |
| 
 | |
| 	    if (!$att = get_record('attendance_sessions', 'id', $sessionid) ) { | |
| 	        error('No such session in this course'); | |
| 	    } | |
| 	     | |
| 		if (isset($confirm)) { | |
| 			delete_records('attendance_log', 'sessionid', $sessionid); | |
| 			delete_records('attendance_sessions', 'id', $sessionid); | |
| 			add_to_log($course->id, 'attendance', 'Session deleted', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
| 			$attforblockrecord = get_record('attforblock', 'course', $course->id); | |
|             attforblock_update_grades($attforblockrecord); | |
| 			redirect('manage.php?id='.$id, get_string('sessiondeleted','attforblock'), 3); | |
| 		} | |
| 		 | |
| 		print_heading(get_string('deletingsession','attforblock').' :: ' .$course->fullname); | |
| 	 | |
| 		notice_yesno(get_string('deletecheckfull', '', get_string('session', 'attforblock')). | |
| 			             '<br /><br />'.userdate($att->sessdate, get_string('strftimedmyhm', 'attforblock')).': '. | |
| 			             ($att->description ? $att->description : get_string('nodescription', 'attforblock')), | |
| 	                     "sessions.php?id=$id&sessionid=$sessionid&action=delete&confirm=1", $_SERVER['HTTP_REFERER']); | |
| 	} | |
| 	 | |
| 	if ($action === 'deleteselected') { | |
| 		$confirm = optional_param('confirm'); | |
| 		if (isset($confirm)) { | |
| 			$sessionid = required_param('sessionid'); | |
| 			$ids = implode(',', explode('_', $sessionid)); | |
| 			delete_records_select('attendance_log', "sessionid IN ($ids)"); | |
| 			delete_records_select('attendance_sessions', "id IN ($ids)"); | |
| 			add_to_log($course->id, 'attendance', 'Several sessions deleted', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
| 			 | |
| 			$attforblockrecord = get_record('attforblock','course',$course->id); | |
| 			attforblock_update_grades($attforblockrecord); | |
| 			redirect('manage.php?id='.$id, get_string('sessiondeleted','attforblock'), 3); | |
| 		} | |
| 		 | |
| 		$fromform = data_submitted(); | |
| 		$slist = implode(',', array_keys($fromform->sessid)); | |
| 		$sessions = get_records_list('attendance_sessions', 'id', $slist, 'sessdate'); | |
| 		 | |
| 		print_heading(get_string('deletingsession','attforblock').' :: ' .$course->fullname); | |
| 		$message = '<br />'; | |
| 		foreach ($sessions as $att) { | |
| 			$message .= '<br />'.userdate($att->sessdate, get_string('strftimedmyhm', 'attforblock')).': '. | |
| 			             ($att->description ? $att->description : get_string('nodescription', 'attforblock')); | |
| 		} | |
| 		 | |
| 		$slist = implode('_', array_keys($fromform->sessid)); | |
| 		notice_yesno(get_string('deletecheckfull', '', get_string('sessions', 'attforblock')).$message, | |
| 	                     "sessions.php?id=$id&sessionid=$slist&action=deleteselected&confirm=1", $_SERVER['HTTP_REFERER']); | |
| 	} | |
| 
 | |
| 	////////////////////////////////////////////////////////// | |
| 	// Change duration | |
| 	////////////////////////////////////////////////////////// | |
| 	 | |
| 	if ($action === 'changeduration') { | |
| 		$fromform = data_submitted(); | |
| 		$slist = isset($fromform->sessid) ? implode('_', array_keys($fromform->sessid)) : ''; | |
| 		 | |
| 		$mform_duration = new mod_attforblock_duration_form('sessions.php', array('course'=>$course,  | |
| 																  'cm'=>$cm,  | |
| 																  'modcontext'=>$context, | |
| 																  'ids'=>$slist)); | |
| 	    if ($mform_duration->is_cancelled()) { | |
| 	    	redirect('manage.php?id='.$id); | |
| 	    } | |
| 	    if ($fromform = $mform_duration->get_data()) { | |
| 	    	$now = time(); | |
| 	    	$slist = implode(',', explode('_', $fromform->ids)); | |
| 		    if (!$sessions = get_records_list('attendance_sessions', 'id', $slist) ) { | |
| 		        error('No such session in this course'); | |
| 		    } | |
| 			foreach ($sessions as $sess) { | |
| 				$sess->duration = $fromform->durtime['hours']*HOURSECS + $fromform->durtime['minutes']*MINSECS; | |
| 				$sess->timemodified = $now; | |
| 				update_record('attendance_sessions', $sess); | |
| 			} | |
| 			add_to_log($course->id, 'attendance', 'Session updated', 'mod/attforblock/manage.php?id='.$id, $user->lastname.' '.$user->firstname); | |
| 			redirect('manage.php?id='.$id, get_string('sessionupdated','attforblock'), 3); | |
| 		} | |
| 		print_heading(get_string('update','attforblock').' ' .get_string('attendanceforthecourse','attforblock').' :: ' .$course->fullname); | |
| 		$mform_duration->display(); | |
| 		 | |
| 	} | |
| 		 | |
| 	print_footer($course); | |
| 	 | |
| 	?>	
 | |
| 
 |