@ -26,6 +26,9 @@ class Attendance
const UPDATED_ATTENDANCE_LOG_TYPE = 'updated_attendance_sheet';
const LOCKED_ATTENDANCE_LOG_TYPE = 'locked_attendance_sheet';
/**
* Constructor
*/
public function __construct()
{
//$this->course_int_id = api_get_course_int_id();
@ -35,19 +38,21 @@ class Attendance
* Get the total number of attendance inside current course and current session
* @see SortableTable#get_total_number_of_items()
*/
static function get_number_of_attendances($active = -1)
public static function get_number_of_attendances($active = -1)
{
$tbl_attendance = Database :: get_course_table(TABLE_ATTENDANCE);
$session_id = api_get_session_id();
$condition_session = api_get_session_condition($session_id);
$course_id = api_get_course_int_id();
$sql = "SELECT COUNT(att.id) AS total_number_of_items FROM $tbl_attendance att
$sql = "SELECT COUNT(att.id) AS total_number_of_items
FROM $tbl_attendance att
WHERE c_id = $course_id $condition_session ";
if ($active == 1 || $active == 0) {
$sql .= "AND att.active = $active";
}
$res = Database::query($sql);
$obj = Database::fetch_object($res);
return $obj->total_number_of_items;
}
@ -57,7 +62,7 @@ class Attendance
* @param int session id (optional)
* @return array attendances list
*/
function get_attendances_list($course_id = '', $session_id = null)
public function get_attendances_list($course_id = '', $session_id = null)
{
// Initializing database table and variables
$tbl_attendance = Database :: get_course_table(TABLE_ATTENDANCE);
@ -82,6 +87,7 @@ class Attendance
$data[$row['id']] = $row;
}
}
return $data;
}
@ -93,7 +99,7 @@ class Attendance
* @param string Order (ASC,DESC)
* @see SortableTable#get_table_data($from)
*/
static function get_attendance_data($from, $number_of_items, $column, $direction)
public static function get_attendance_data($from, $number_of_items, $column, $direction)
{
$tbl_attendance = Database :: get_course_table(TABLE_ATTENDANCE);
$course_id = api_get_course_int_id();
@ -122,7 +128,8 @@ class Attendance
att.session_id
FROM $tbl_attendance att
WHERE c_id = $course_id $active_plus $condition_session
ORDER BY col$column $direction LIMIT $from,$number_of_items ";
ORDER BY col$column $direction
LIMIT $from,$number_of_items ";
$res = Database::query($sql);
$attendances = array ();
@ -159,8 +166,7 @@ class Attendance
if ($attendance[5] == 1) {
$attendance[3] = '< center > '.$attendance[3].'< / center > ';
}
else {
} else {
$attendance[3] = '< center > < span class = "muted" > '.$attendance[3].'< / span > < / center > ';
}
@ -220,8 +226,8 @@ class Attendance
}
/**
* Get the attendaces by id to display on the current page
* @param int attendance id
* Get the attendan ces by id to display on the current page
* @param int $attendance_ id
* @return array attendance data
*/
public function get_attendance_by_id($attendance_id)
@ -230,7 +236,8 @@ class Attendance
$attendance_id = intval($attendance_id);
$course_id = api_get_course_int_id();
$attendance_data = array();
$sql = "SELECT * FROM $tbl_attendance WHERE c_id = $course_id AND id = '$attendance_id'";
$sql = "SELECT * FROM $tbl_attendance
WHERE c_id = $course_id AND id = '$attendance_id'";
$res = Database::query($sql);
if (Database::num_rows($res) > 0) {
while ($row = Database::fetch_array($res)) {
@ -241,7 +248,7 @@ class Attendance
}
/**
* Add attendaces sheet inside table. This is the *list of* dates, not
* Add attendan ces sheet inside table. This is the *list of* dates, not
* a specific date in itself.
* @param bool true for adding link in gradebook or false otherwise (optional)
* @return int last attendance id
@ -279,7 +286,18 @@ class Attendance
$link_info = is_resource_in_course_gradebook($course_code,7,$last_id,$session_id);
$link_id = $link_info['id'];
if (!$link_info) {
add_resource_to_course_gradebook($this->category_id, $course_code, 7, $last_id, $title_gradebook,$weight_calification,$value_calification,$description,1,$session_id);
add_resource_to_course_gradebook(
$this->category_id,
$course_code,
7,
$last_id,
$title_gradebook,
$weight_calification,
$value_calification,
$description,
1,
$session_id
);
} else {
Database::query('UPDATE '.$table_link.' SET weight='.$weight_calification.' WHERE id='.$link_id.'');
}
@ -288,7 +306,7 @@ class Attendance
}
/**
* edit attendaces inside table
* edit attendan ces inside table
* @param int attendance id
* @param bool true for adding link in gradebook or false otherwise (optional)
* @return int last id
@ -324,7 +342,18 @@ class Attendance
$description = '';
$link_id = is_resource_in_course_gradebook($course_code, 7, $attendance_id, $session_id);
if (!$link_id) {
add_resource_to_course_gradebook($this->category_id, $course_code, 7, $attendance_id, $title_gradebook,$weight_calification,$value_calification,$description,1,$session_id);
add_resource_to_course_gradebook(
$this->category_id,
$course_code,
7,
$attendance_id,
$title_gradebook,
$weight_calification,
$value_calification,
$description,
1,
$session_id
);
} else {
Database::query('UPDATE '.$table_link.' SET weight='.$weight_calification.' WHERE id='.$link_id.'');
}
@ -341,7 +370,7 @@ class Attendance
*/
public function attendance_restore($attendance_id)
{
global $_course ;
$_course = api_get_course_info() ;
$tbl_attendance = Database :: get_course_table(TABLE_ATTENDANCE);
$user_id = api_get_user_id();
$course_id = api_get_course_int_id();
@ -366,11 +395,12 @@ class Attendance
api_item_property_update($_course, TOOL_ATTENDANCE, $attendance_id,"restore", $user_id);
}
}
return $affected_rows;
}
/**
* delete attenda ces
* Delete attendan ces
* @param int|array one or many attendances id
* @return int affected rows
*/
@ -398,7 +428,13 @@ class Attendance
$affected_rows = Database::affected_rows();
if (!empty($affected_rows)) {
// update row item property table
api_item_property_update($_course, TOOL_ATTENDANCE, $attendance_id,"delete", $user_id);
api_item_property_update(
$_course,
TOOL_ATTENDANCE,
$attendance_id,
"delete",
$user_id
);
}
}
return $affected_rows;
@ -415,7 +451,8 @@ class Attendance
$course_id = api_get_course_int_id();
$attendance_id = intval($attendance_id);
$locked = ($lock)?1:0;
$upd = "UPDATE $tbl_attendance SET locked = $locked WHERE c_id = $course_id AND id = $attendance_id";
$upd = "UPDATE $tbl_attendance SET locked = $locked
WHERE c_id = $course_id AND id = $attendance_id";
Database::query($upd);
$affected_rows = Database::affected_rows();
if ($affected_rows & & $lock) {
@ -423,14 +460,19 @@ class Attendance
$lastedit_date = Date('Y-m-d H:i:s');
$lastedit_type = self::LOCKED_ATTENDANCE_LOG_TYPE;
$lastedit_user_id = api_get_user_id();
$save_attendance_log = $this->save_attendance_sheet_log($attendance_id, $lastedit_date, $lastedit_type, $lastedit_user_id);
$this->save_attendance_sheet_log(
$attendance_id,
$lastedit_date,
$lastedit_type,
$lastedit_user_id
);
}
return $affected_rows;
}
/**
* Get registered users inside current course
* @param int attendance id for showing attendance result field (optional)
* @param int $attendance_id attendance id for showing attendance result field (optional)
* @return array users data
*/
public function get_users_rel_course($attendance_id = 0)
@ -438,9 +480,19 @@ class Attendance
$current_session_id = api_get_session_id();
$current_course_id = api_get_course_id();
if (!empty($current_session_id)) {
$a_course_users = CourseManager :: get_user_list_from_course_code($current_course_id, $current_session_id,'','lastname');
$a_course_users = CourseManager:: get_user_list_from_course_code(
$current_course_id,
$current_session_id,
'',
'lastname'
);
} else {
$a_course_users = CourseManager :: get_user_list_from_course_code($current_course_id, 0, '','lastname');
$a_course_users = CourseManager:: get_user_list_from_course_code(
$current_course_id,
0,
'',
'lastname'
);
}
// get registered users inside current course
$a_users = array();
@ -453,9 +505,16 @@ class Attendance
$user_status_in_course = null;
if (api_get_session_id()) {
$user_status_in_session = SessionManager::get_user_status_in_course_session($uid, $current_course_id, $current_session_id);
$user_status_in_session = SessionManager::get_user_status_in_course_session(
$uid,
$current_course_id,
$current_session_id
);
} else {
$user_status_in_course = CourseManager::get_user_in_course_status($uid, $current_course_id);
$user_status_in_course = CourseManager::get_user_in_course_status(
$uid,
$current_course_id
);
}
//Not taking into account DRH or COURSEMANAGER
@ -463,7 +522,6 @@ class Attendance
if (!empty($attendance_id)) {
$user_faults = $this->get_faults_of_user($uid, $attendance_id);
$value['attendance_result'] = $user_faults['faults'].'/'.$user_faults['total'].' ('.$user_faults['faults_porcent'].'%)';
$value['result_color_bar'] = $user_faults['color_bar'];
}
@ -491,10 +549,10 @@ class Attendance
}
/**
* add attendaces sheet inside table
* @param int attendance calendar id
* @param array present users during current class
* @param int attendance id
* add attendan ces sheet inside table
* @param int $calendar_id attendance calendar id
* @param array $users_present present users during current class
* @param int $attendance_ id
* @return int affected rows
*/
public function attendance_sheet_add($calendar_id, $users_present, $attendance_id)
@ -524,7 +582,8 @@ class Attendance
foreach ($users_present as $user_present) {
$uid = intval($user_present);
// check if user already was registered with the $calendar_id
$sql = "SELECT user_id FROM $tbl_attendance_sheet WHERE c_id = $course_id AND user_id='$uid' AND attendance_calendar_id = '$calendar_id'";
$sql = "SELECT user_id FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND user_id='$uid' AND attendance_calendar_id = '$calendar_id'";
$rs = Database::query($sql);
if (Database::num_rows($rs) == 0) {
$sql = "INSERT INTO $tbl_attendance_sheet SET
@ -535,7 +594,8 @@ class Attendance
Database::query($sql);
$affected_rows += Database::affected_rows();
} else {
$sql = "UPDATE $tbl_attendance_sheet SET presence = 1 WHERE c_id = $course_id AND user_id ='$uid' AND attendance_calendar_id = '$calendar_id'";
$sql = "UPDATE $tbl_attendance_sheet SET presence = 1
WHERE c_id = $course_id AND user_id ='$uid' AND attendance_calendar_id = '$calendar_id'";
Database::query($sql);
$affected_rows += Database::affected_rows();
}
@ -545,7 +605,8 @@ class Attendance
foreach ($users_absent as $user_absent) {
$uid = intval($user_absent);
// check if user already was registered with the $calendar_id
$sql = "SELECT user_id FROM $tbl_attendance_sheet WHERE c_id = $course_id AND user_id='$uid' AND attendance_calendar_id = '$calendar_id'";
$sql = "SELECT user_id FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND user_id='$uid' AND attendance_calendar_id = '$calendar_id'";
$rs = Database::query($sql);
if (Database::num_rows($rs) == 0) {
$sql = "INSERT INTO $tbl_attendance_sheet SET
@ -556,14 +617,16 @@ class Attendance
Database::query($sql);
$affected_rows += Database::affected_rows();
} else {
$sql = "UPDATE $tbl_attendance_sheet SET presence = 0 WHERE c_id = $course_id AND user_id ='$uid' AND attendance_calendar_id = '$calendar_id'";
$sql = "UPDATE $tbl_attendance_sheet SET presence = 0
WHERE c_id = $course_id AND user_id ='$uid' AND attendance_calendar_id = '$calendar_id'";
Database::query($sql);
$affected_rows += Database::affected_rows();
}
}
// update done_attendance inside attendance calendar table
$sql = "UPDATE $tbl_attendance_calendar SET done_attendance = 1 WHERE c_id = $course_id AND id = '$calendar_id'";
$sql = "UPDATE $tbl_attendance_calendar SET done_attendance = 1
WHERE c_id = $course_id AND id = '$calendar_id'";
Database::query($sql);
// save users' results
@ -574,7 +637,13 @@ class Attendance
$lastedit_date = Date('Y-m-d H:i:s');
$lastedit_user_id = api_get_user_id();
$calendar_date_value = $calendar_data['date_time'];
$save_attendance_log = $this->save_attendance_sheet_log($attendance_id, $lastedit_date, $lastedit_type, $lastedit_user_id, $calendar_date_value);
$this->save_attendance_sheet_log(
$attendance_id,
$lastedit_date,
$lastedit_type,
$lastedit_user_id,
$calendar_date_value
);
}
return $affected_rows;
@ -582,8 +651,8 @@ class Attendance
/**
* update users' attendance results
* @param array registered users inside current course
* @param int attendance id
* @param array $user_ids registered users inside current course
* @param int $attendance_ id
* @return void
*/
public function update_users_results($user_ids, $attendance_id)
@ -608,7 +677,8 @@ class Attendance
foreach ($user_ids as $uid) {
$count_presences = 0;
if (count($calendar_ids) > 0) {
$sql = "SELECT count(presence) as count_presences FROM $tbl_attendance_sheet
$sql = "SELECT count(presence) as count_presences
FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND user_id = '$uid' AND attendance_calendar_id IN(".implode(',',$calendar_ids).") AND presence = 1";
$rs_count = Database::query($sql);
$row_count = Database::fetch_array($rs_count);
@ -636,7 +706,8 @@ class Attendance
}
// update attendance qualify max
$count_done_calendar = self::get_done_attendance_calendar($attendance_id);
$sql = "UPDATE $tbl_attendance SET attendance_qualify_max='$count_done_calendar' WHERE c_id = $course_id AND id = '$attendance_id'";
$sql = "UPDATE $tbl_attendance SET attendance_qualify_max='$count_done_calendar'
WHERE c_id = $course_id AND id = '$attendance_id'";
Database::query($sql);
}
@ -700,22 +771,18 @@ class Attendance
* Get results of faults (absents) by user
* @param int user id
* @param int attendance id
* @return array results containing number of faults, total done attendance, porcent of faults and color depend on result (red, orange)
* @return array results containing number of faults, total done attendance,
* percent of faults and color depend on result (red, orange)
*/
public function get_faults_of_user($user_id, $attendance_id)
{
// initializing database table and variables
$tbl_attendance_result = Database::get_course_table(TABLE_ATTENDANCE_RESULT);
$user_id = intval($user_id);
$attendance_id = intval($attendance_id);
$results = array();
$attendance_data = $this->get_attendance_by_id($attendance_id);
$calendar_count = self::get_number_of_attendance_calendar($attendance_id);
$total_done_attendance = $attendance_data['attendance_qualify_max'];
$attendance_user_score = $this->get_user_score($user_id, $attendance_id);
//This is the main change of the BT#1381
@ -743,13 +810,12 @@ class Attendance
/**
* Get results of faults average for all courses by user
* @param int user id
* @param int $user_ id
* @return array results containing number of faults, total done attendance,
* percentage of faults and color depend on result (red, orange)
*/
public function get_faults_average_inside_courses($user_id)
{
// get all courses of current user
$courses = CourseManager::get_courses_list_by_user_id($user_id, true);
@ -792,7 +858,8 @@ class Attendance
/**
* Get results of faults average by course
* @param int user id
* @param int $user_id
* @param string $course_code
* @param int Session id (optional)
* @return array results containing number of faults,
* total done attendance, porcent of faults and color depend on result (red, orange)
@ -810,7 +877,8 @@ class Attendance
foreach ($attendances_by_course as $attendance) {
// Get total faults and total weight
$total_done_attendance = $attendance['attendance_qualify_max'];
$sql = "SELECT score FROM $tbl_attendance_result WHERE c_id = {$course_info['real_id']} AND user_id=$user_id AND attendance_id=".$attendance['id'];
$sql = "SELECT score FROM $tbl_attendance_result
WHERE c_id = {$course_info['real_id']} AND user_id=$user_id AND attendance_id=".$attendance['id'];
$rs = Database::query($sql);
$score = 0;
if (Database::num_rows($rs) > 0) {
@ -832,8 +900,8 @@ class Attendance
/**
* Get registered users' attendance sheet inside current course
* @param int attendance id
* @param int user id for showing data for only one user (optional)
* @param int $attendance_ id
* @param int $user_ id for showing data for only one user (optional)
* @return array users attendance sheet data
*/
public function get_users_attendance_sheet($attendance_id, $user_id = 0)
@ -858,7 +926,11 @@ class Attendance
if (count($calendar_ids) > 0 & & count($user_ids) > 0) {
foreach ($user_ids as $uid) {
$sql = "SELECT * FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND user_id = '$uid' AND attendance_calendar_id IN(".implode(',',$calendar_ids).") ";
WHERE
c_id = $course_id AND
user_id = '$uid' AND
attendance_calendar_id IN(".implode(',',$calendar_ids).")
";
$res = Database::query($sql);
if (Database::num_rows($res) > 0) {
while ($row = Database::fetch_array($res)) {
@ -875,7 +947,8 @@ class Attendance
FROM $tbl_attendance_sheet att
INNER JOIN $tbl_attendance_calendar cal
ON cal.id = att.attendance_calendar_id
WHERE att.c_id = $course_id AND
WHERE
att.c_id = $course_id AND
cal.c_id = $course_id AND
att.user_id = '$user_id' AND
att.attendance_calendar_id IN(".implode(',',$calendar_ids).")
@ -904,7 +977,12 @@ class Attendance
$course_id = api_get_course_int_id();
$sql = "SELECT id FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND attendance_id = '$attendance_id' AND done_attendance = 0 ORDER BY date_time limit 1";
WHERE
c_id = $course_id AND
attendance_id = '$attendance_id' AND
done_attendance = 0
ORDER BY date_time
LIMIT 1";
$rs = Database::query($sql);
$next_calendar_id = 0;
if (Database::num_rows($rs) > 0) {
@ -924,7 +1002,13 @@ class Attendance
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$course_id = api_get_course_int_id();
$attendance_id = intval($attendance_id);
$sql = "SELECT id, date_time FROM $tbl_attendance_calendar WHERE c_id = $course_id AND attendance_id = '$attendance_id' AND done_attendance = 0 ORDER BY date_time limit 1";
$sql = "SELECT id, date_time FROM $tbl_attendance_calendar
WHERE
c_id = $course_id AND
attendance_id = '$attendance_id' AND
done_attendance = 0
ORDER BY date_time
limit 1";
$rs = Database::query($sql);
$next_calendar_datetime = 0;
if (Database::num_rows($rs) > 0) {
@ -936,8 +1020,8 @@ class Attendance
/**
* Get user' score from current attendance
* @param int user id
* @param int attendance id
* @param int $user_ id
* @param int $attendance_ id
* @return int score
*/
public function get_user_score($user_id, $attendance_id)
@ -946,7 +1030,11 @@ class Attendance
$user_id = intval($user_id);
$attendance_id = intval($attendance_id);
$course_id = api_get_course_int_id();
$sql = "SELECT score FROM $tbl_attendance_result WHERE c_id = $course_id AND user_id='$user_id' AND attendance_id='$attendance_id'";
$sql = "SELECT score FROM $tbl_attendance_result
WHERE
c_id = $course_id AND
user_id='$user_id' AND
attendance_id='$attendance_id'";
$rs = Database::query($sql);
$score = 0;
if (Database::num_rows($rs) > 0) {
@ -966,7 +1054,8 @@ class Attendance
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$calendar_id = intval($calendar_id);
$course_id = api_get_course_int_id();
$sql = "SELECT * FROM $tbl_attendance_calendar WHERE c_id = $course_id AND id = '$calendar_id' ";
$sql = "SELECT * FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND id = '$calendar_id' ";
$rs = Database::query($sql);
$data = array();
if (Database::num_rows($rs) > 0) {
@ -989,7 +1078,8 @@ class Attendance
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$attendance_id = intval($attendance_id);
$course_id = api_get_course_int_id();
$sql = "SELECT * FROM $tbl_attendance_calendar WHERE c_id = $course_id AND attendance_id = '$attendance_id' ";
$sql = "SELECT * FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND attendance_id = '$attendance_id' ";
if (!in_array($type, array('today', 'all', 'all_done', 'all_not_done','calendar_id'))) {
$type = 'all';
}
@ -1037,7 +1127,7 @@ class Attendance
/**
* Get number of attendance calendar inside current attendance
* @param int attendance id
* @param int $attendance_ id
* @return int number of dates in attendance calendar
*/
public static function get_number_of_attendance_calendar($attendance_id)
@ -1050,20 +1140,24 @@ class Attendance
$rs = Database::query($sql);
$row = Database::fetch_row($rs);
$count = $row[0];
return $count;
}
/**
* Get count dates inside attendance calendar by attendance id
* @param int attendance id
* @param int $attendance_ id
* @return int count of dates
*/
public static function get_count_dates_inside_attendance_calendar($attendance_id) {
public static function get_count_dates_inside_attendance_calendar($attendance_id)
{
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$attendance_id = intval($attendance_id);
$course_id = api_get_course_int_id();
$sql = "SELECT count(id) FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND attendance_id = '$attendance_id'";
WHERE
c_id = $course_id AND
attendance_id = '$attendance_id'";
$rs = Database::query($sql);
$count = 0;
if (Database::num_rows($rs) > 0) {
@ -1075,7 +1169,7 @@ class Attendance
/**
* check if all calendar of an attendance is done
* @param int attendance id
* @param int $attendance_ id
* @return bool True if all calendar is done, otherwise false
*/
public static function is_all_attendance_calendar_done($attendance_id)
@ -1094,7 +1188,7 @@ class Attendance
/**
* check if an attendance is locked
* @param int attendance id
* @param int $attendance_ id
* @param bool
*/
public static function is_locked_attendance($attendance_id)
@ -1117,7 +1211,10 @@ class Attendance
$course_id = api_get_course_int_id();
// check if datetime already exists inside the table
$sql = "SELECT id FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND date_time='".Database::escape_string($this->date_time)."' AND attendance_id = '$attendance_id'";
WHERE
c_id = $course_id AND
date_time='".Database::escape_string($this->date_time)."' AND
attendance_id = '$attendance_id'";
$rs = Database::query($sql);
if (Database::num_rows($rs) == 0) {
$sql = "INSERT INTO $tbl_attendance_calendar SET
@ -1131,20 +1228,19 @@ class Attendance
// update locked attendance
$is_all_calendar_done = self::is_all_attendance_calendar_done($attendance_id);
if (!$is_all_calendar_done) {
$unlock = self::lock_attendance($attendance_id, false);
self::lock_attendance($attendance_id, false);
} else {
$unlock = self::lock_attendance($attendance_id);
self::lock_attendance($attendance_id);
}
return $affected_rows;
}
/**
* save repeated date inside attendance calendar table
* @param int attendance id
* @param int start date in tms
* @param int end date in tms
* @param string repeat type daily, weekly, monthlyByDate
* @param int $attendance_id
* @param int $start_date start date in tms
* @param int $end_date end date in tms
* @param string $repeat_type daily, weekly, monthlyByDate
*/
public function attendance_repeat_calendar_add($attendance_id, $start_date, $end_date, $repeat_type)
{
@ -1161,21 +1257,18 @@ class Attendance
case 'daily':
$j = 1;
for ($i = $start_date + 86400; ($i < = $end_date); $i += 86400) {
//$datetimezone = api_get_utc_date_add(api_get_utc_datetime($start_date), 0 , 0, $j); //to support europe timezones
$datetimezone = api_get_utc_datetime($i);
$this->set_date_time($datetimezone);
$res = $this->attendance_calendar_add($attendance_id);
$this->attendance_calendar_add($attendance_id);
$j++;
}
break;
exit;
case 'weekly':
$j = 1;
for ($i = $start_date + 604800; ($i < = $end_date); $i += 604800) {
$datetimezone = api_get_utc_datetime($i);
//$datetimezone = api_get_utc_date_add(api_get_utc_datetime($start_date), 0 , 0, $j*7); //to support europe timezones
$this->set_date_time($datetimezone);
$res = $this->attendance_calendar_add($attendance_id);
$this->attendance_calendar_add($attendance_id);
$j++;
}
break;
@ -1184,9 +1277,8 @@ class Attendance
//@todo fix bug with february
for ($i = $start_date + 2419200; ($i < = $end_date); $i += 2419200) {
$datetimezone = api_get_utc_datetime($i);
//$datetimezone = api_get_utc_date_add(api_get_utc_datetime($start_date), 0 , $j); //to support europe timezones
$this->set_date_time($datetimezone);
$res = $this->attendance_calendar_add($attendance_id);
$this->attendance_calendar_add($attendance_id);
$j++;
}
break;
@ -1236,7 +1328,8 @@ class Attendance
WHERE c_id = $course_id AND date_time = '".Database::escape_string($this->date_time)."' AND attendance_id = '$attendance_id'";
$rs = Database::query($sql);
if (Database::num_rows($rs) == 0) {
$sql = "UPDATE $tbl_attendance_calendar SET date_time='".Database::escape_string($this->date_time)."' WHERE c_id = $course_id AND id = '".intval($calendar_id)."'";
$sql = "UPDATE $tbl_attendance_calendar SET date_time='".Database::escape_string($this->date_time)."'
WHERE c_id = $course_id AND id = '".intval($calendar_id)."'";
Database::query($sql);
$affected_rows = Database::affected_rows();
}
@ -1244,11 +1337,10 @@ class Attendance
// update locked attendance
$is_all_calendar_done = self::is_all_attendance_calendar_done($attendance_id);
if (!$is_all_calendar_done) {
$unlock = self::lock_attendance($attendance_id, false);
self::lock_attendance($attendance_id, false);
} else {
$unlock = self::lock_attendance($attendance_id);
self::lock_attendance($attendance_id);
}
return $affected_rows;
}
@ -1272,24 +1364,27 @@ class Attendance
if ($all_delete) {
$attendance_calendar = $this->get_attendance_calendar($attendance_id);
$calendar_ids = array();
// get all dates from calendar by current attendance
if (!empty($attendance_calendar)) {
foreach ($attendance_calendar as $cal) {
// delete all data from attendance sheet
$sql = "DELETE FROM $tbl_attendance_sheet WHERE c_id = $course_id AND attendance_calendar_id = '".intval($cal['id'])."'";
$sql = "DELETE FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND attendance_calendar_id = '".intval($cal['id'])."'";
Database::query($sql);
// delete data from attendance calendar
$sql = "DELETE FROM $tbl_attendance_calendar WHERE c_id = $course_id AND id = '".intval($cal['id'])."'";
$sql = "DELETE FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND id = '".intval($cal['id'])."'";
Database::query($sql);
}
}
} else {
// delete just one row from attendance sheet by the calendar id
$sql = "DELETE FROM $tbl_attendance_sheet WHERE c_id = $course_id AND attendance_calendar_id = '".intval($calendar_id)."'";
$sql = "DELETE FROM $tbl_attendance_sheet
WHERE c_id = $course_id AND attendance_calendar_id = '".intval($calendar_id)."'";
Database::query($sql);
// delete data from attendance calendar
$sql = "DELETE FROM $tbl_attendance_calendar WHERE c_id = $course_id AND id = '".intval($calendar_id)."'";
$sql = "DELETE FROM $tbl_attendance_calendar
WHERE c_id = $course_id AND id = '".intval($calendar_id)."'";
Database::query($sql);
}
@ -1306,65 +1401,80 @@ class Attendance
* $array('Y'=>'2010', 'F' => '02', 'd' => '10', 'H' => '12', 'i' => '30')
* @return string date and time e.g: '2010-02-10 12:30:00'
*/
public function build_datetime_from_array($array) {
public function build_datetime_from_array($array)
{
return return_datetime_from_array($array);
}
/** Setters for fields of attendances tables **/
public function set_session_id($session_id) {
public function set_session_id($session_id)
{
$this->session_id = $session_id;
}
public function set_course_id($course_id) {
public function set_course_id($course_id)
{
$this->course_id = $course_id;
}
public function set_date_time($datetime) {
public function set_date_time($datetime)
{
$this->date_time = $datetime;
}
public function set_name($name) {
public function set_name($name)
{
$this->name = $name;
}
public function set_description($description) {
public function set_description($description)
{
$this->description = $description;
}
public function set_attendance_qualify_title($attendance_qualify_title) {
public function set_attendance_qualify_title($attendance_qualify_title)
{
$this->attendance_qualify_title = $attendance_qualify_title;
}
public function set_attendance_weight($attendance_weight) {
public function set_attendance_weight($attendance_weight)
{
$this->attendance_weight = $attendance_weight;
}
/** Getters for fields of attendances tables **/
public function get_session_id() {
public function get_session_id()
{
return $this->session_id;
}
public function get_course_id() {
public function get_course_id()
{
return $this->course_id;
}
public function get_date_time() {
public function get_date_time()
{
return $this->date_time;
}
public function get_name($name) {
public function get_name($name)
{
return $this->name;
}
public function get_description($description) {
public function get_description($description)
{
return $this->description;
}
public function get_attendance_qualify_title($attendance_qualify_title) {
public function get_attendance_qualify_title($attendance_qualify_title)
{
return $this->attendance_qualify_title;
}
public function get_attendance_weight($attendance_weight) {
public function get_attendance_weight($attendance_weight)
{
return $this->attendance_weight;
}
}