|
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Defines a gradebook AbstractLink object.
|
|
|
|
|
|
* To implement specific links,
|
|
|
|
|
|
* extend this class and define a type in LinkFactory.
|
|
|
|
|
|
* Use the methods in LinkFactory to create link objects.
|
|
|
|
|
|
* @author Bert Stepp<EFBFBD>
|
|
|
|
|
|
* @package dokeos.gradebook
|
|
|
|
|
|
*/
|
|
|
|
|
|
abstract class AbstractLink implements GradebookItem
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
// PROPERTIES
|
|
|
|
|
|
|
|
|
|
|
|
protected $id;
|
|
|
|
|
|
protected $type;
|
|
|
|
|
|
protected $ref_id;
|
|
|
|
|
|
protected $user_id;
|
|
|
|
|
|
protected $course_code;
|
|
|
|
|
|
protected $category;
|
|
|
|
|
|
protected $link_date;
|
|
|
|
|
|
protected $weight;
|
|
|
|
|
|
protected $visible;
|
|
|
|
|
|
|
|
|
|
|
|
// CONSTRUCTORS
|
|
|
|
|
|
|
|
|
|
|
|
function AbstractLink()
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// GETTERS AND SETTERS
|
|
|
|
|
|
|
|
|
|
|
|
public function get_id()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_type()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->type;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_ref_id()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->ref_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_user_id()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->user_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_course_code()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->course_code;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_category_id()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->category;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_date()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->link_date;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_weight()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->weight;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function is_visible()
|
|
|
|
|
|
{
|
|
|
|
|
|
return $this->visible;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function set_id ($id)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->id = $id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_type ($type)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->type = $type;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_ref_id ($ref_id)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->ref_id = $ref_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_user_id ($user_id)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->user_id = $user_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_course_code ($course_code)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->course_code = $course_code;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_category_id ($category_id)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->category = $category_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_date ($date)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->link_date = $date;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_weight ($weight)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->weight = $weight;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_visible ($visible)
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->visible = $visible;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// CRUD FUNCTIONS
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Retrieve links and return them as an array of extensions of AbstractLink.
|
|
|
|
|
|
* To keep consistency, do not call this method but LinkFactory::load instead.
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function load ($id = null, $type = null, $ref_id = null, $user_id = null, $course_code = null, $category_id = null, $visible = null)
|
|
|
|
|
|
{
|
|
|
|
|
|
$tbl_grade_links = Database :: get_main_table(TABLE_MAIN_GRADEBOOK_LINK);
|
|
|
|
|
|
$sql='SELECT id,type,ref_id,user_id,course_code,category_id,date,weight,visible FROM '.$tbl_grade_links;
|
|
|
|
|
|
$paramcount = 0;
|
|
|
|
|
|
if (isset ($id))
|
|
|
|
|
|
{
|
|
|
|
|
|
$sql.= ' WHERE id = '.$id;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($type))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= ' type = '.$type;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($ref_id))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= ' ref_id = '.$ref_id;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($user_id))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= ' user_id = '.$user_id;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($course_code))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= " course_code = '".$course_code."'";
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($category_id))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= ' category_id = '.$category_id;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (isset ($visible))
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($paramcount != 0) $sql .= ' AND';
|
|
|
|
|
|
else $sql .= ' WHERE';
|
|
|
|
|
|
$sql .= ' visible = '.$visible;
|
|
|
|
|
|
$paramcount ++;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
|
|
$links = AbstractLink::create_objects_from_mysql_result($result);
|
|
|
|
|
|
return $links;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private function create_objects_from_mysql_result($result)
|
|
|
|
|
|
{
|
|
|
|
|
|
$links=array();
|
|
|
|
|
|
while ($data=mysql_fetch_array($result))
|
|
|
|
|
|
{
|
|
|
|
|
|
$link = LinkFactory::create(intval($data['type']));
|
|
|
|
|
|
$link->set_id($data['id']);
|
|
|
|
|
|
$link->set_type($data['type']);
|
|
|
|
|
|
$link->set_ref_id($data['ref_id']);
|
|
|
|
|
|
$link->set_user_id($data['user_id']);
|
|
|
|
|
|
$link->set_course_code($data['course_code']);
|
|
|
|
|
|
$link->set_category_id($data['category_id']);
|
|
|
|
|
|
$link->set_date($data['date']);
|
|
|
|
|
|
$link->set_weight($data['weight']);
|
|
|
|
|
|
$link->set_visible($data['visible']);
|
|
|
|
|
|
$links[]=$link;
|
|
|
|
|
|
}
|
|
|
|
|
|
return $links;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Insert this link into the database
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function add()
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->add_linked_data();
|
|
|
|
|
|
|
|
|
|
|
|
if (isset($this->type) && isset($this->ref_id) && isset($this->user_id) && isset($this->course_code)
|
|
|
|
|
|
&& isset($this->category) && isset($this->weight) && isset($this->visible))
|
|
|
|
|
|
{
|
|
|
|
|
|
$tbl_grade_links = Database :: get_main_table(TABLE_MAIN_GRADEBOOK_LINK);
|
|
|
|
|
|
|
|
|
|
|
|
$sql = 'INSERT INTO '.$tbl_grade_links
|
|
|
|
|
|
.' (type,ref_id,user_id,course_code,category_id,weight,visible';
|
|
|
|
|
|
if (isset($this->link_date)) $sql .= ',date';
|
|
|
|
|
|
$sql .= ') VALUES ('
|
|
|
|
|
|
.$this->get_type()
|
|
|
|
|
|
.','.$this->get_ref_id()
|
|
|
|
|
|
.','.$this->get_user_id()
|
|
|
|
|
|
.",'".$this->get_course_code()."'"
|
|
|
|
|
|
.','.$this->get_category_id()
|
|
|
|
|
|
.','.$this->get_weight()
|
|
|
|
|
|
.','.$this->is_visible();
|
|
|
|
|
|
if (isset($this->link_date)) $sql .= ','.$this->get_date();
|
|
|
|
|
|
$sql .= ")";
|
|
|
|
|
|
|
|
|
|
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
|
|
$this->set_id(mysql_insert_id());
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
die('Error in AbstractLink add: required field empty');
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Update the properties of this link in the database
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function save()
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->save_linked_data();
|
|
|
|
|
|
|
|
|
|
|
|
$tbl_grade_links = Database :: get_main_table(TABLE_MAIN_GRADEBOOK_LINK);
|
|
|
|
|
|
$sql = 'UPDATE '.$tbl_grade_links
|
|
|
|
|
|
.' SET type = '.$this->get_type()
|
|
|
|
|
|
.', ref_id = '.$this->get_ref_id()
|
|
|
|
|
|
.', user_id = '.$this->get_user_id()
|
|
|
|
|
|
.", course_code = '".$this->get_course_code()."'"
|
|
|
|
|
|
.', category_id = '.$this->get_category_id()
|
|
|
|
|
|
.', date = ';
|
|
|
|
|
|
if (isset($this->link_date))
|
|
|
|
|
|
$sql .= $this->get_date();
|
|
|
|
|
|
else
|
|
|
|
|
|
$sql .= 'null';
|
|
|
|
|
|
|
|
|
|
|
|
$sql .= ', weight = '.$this->get_weight()
|
|
|
|
|
|
.', visible = '.$this->is_visible()
|
|
|
|
|
|
.' WHERE id = '.$this->id;
|
|
|
|
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Delete this link from the database
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function delete()
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->delete_linked_data();
|
|
|
|
|
|
|
|
|
|
|
|
$tbl_grade_links = Database :: get_main_table(TABLE_MAIN_GRADEBOOK_LINK);
|
|
|
|
|
|
$sql = 'DELETE FROM '.$tbl_grade_links.' WHERE id = '.$this->id;
|
|
|
|
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// OTHER FUNCTIONS
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Generate an array of possible categories where this link can be moved to.
|
|
|
|
|
|
* Notice: its own parent will be included in the list: it's up to the frontend
|
|
|
|
|
|
* to disable this element.
|
|
|
|
|
|
* @return array 2-dimensional array - every element contains 3 subelements (id, name, level)
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function get_target_categories()
|
|
|
|
|
|
{
|
|
|
|
|
|
// links can only be moved to categories inside this course
|
|
|
|
|
|
|
|
|
|
|
|
$targets = array();
|
|
|
|
|
|
$level = 0;
|
|
|
|
|
|
|
|
|
|
|
|
$crscats = Category::load(null,null,$this->get_course_code(),0);
|
|
|
|
|
|
foreach ($crscats as $cat)
|
|
|
|
|
|
{
|
|
|
|
|
|
$targets[] = array ($cat->get_id(), $cat->get_name(), $level+1);
|
|
|
|
|
|
$targets = $this->add_target_subcategories($targets, $level+1, $cat->get_id());
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return $targets;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Internal function used by get_target_categories()
|
|
|
|
|
|
*/
|
|
|
|
|
|
private function add_target_subcategories($targets, $level, $catid)
|
|
|
|
|
|
{
|
|
|
|
|
|
$subcats = Category::load(null,null,null,$catid);
|
|
|
|
|
|
foreach ($subcats as $cat)
|
|
|
|
|
|
{
|
|
|
|
|
|
$targets[] = array ($cat->get_id(), $cat->get_name(), $level+1);
|
|
|
|
|
|
$targets = $this->add_target_subcategories($targets, $level+1, $cat->get_id());
|
|
|
|
|
|
}
|
|
|
|
|
|
return $targets;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Move this link to the given category.
|
|
|
|
|
|
* If this link moves to outside a course, delete it.
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function move_to_cat($cat)
|
|
|
|
|
|
{
|
|
|
|
|
|
if ($this->get_course_code() != $cat->get_course_code())
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->delete();
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
$this->set_category_id($cat->get_id());
|
|
|
|
|
|
$this->save();
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* Find links by name
|
|
|
|
|
|
* To keep consistency, do not call this method but LinkFactory::find_links instead.
|
|
|
|
|
|
* @todo can be written more efficiently using a new (but very complex) sql query
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function find_links ($name_mask,$selectcat)
|
|
|
|
|
|
{
|
|
|
|
|
|
$rootcat = Category::load($selectcat);
|
|
|
|
|
|
$links = $rootcat[0]->get_links((api_is_allowed_to_create_course() ? null : api_get_user_id()), true);
|
|
|
|
|
|
$foundlinks = array();
|
|
|
|
|
|
foreach ($links as $link)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (!(strpos(strtolower($link->get_name()), strtolower($name_mask)) === false))
|
|
|
|
|
|
$foundlinks[] = $link;
|
|
|
|
|
|
}
|
|
|
|
|
|
return $foundlinks;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Other methods implementing GradebookItem
|
|
|
|
|
|
|
|
|
|
|
|
public function get_item_type()
|
|
|
|
|
|
{
|
|
|
|
|
|
return 'L';
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_icon_name()
|
|
|
|
|
|
{
|
|
|
|
|
|
return 'link';
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ABSTRACT FUNCTIONS - to be implemented by subclass
|
|
|
|
|
|
|
|
|
|
|
|
abstract function has_results();
|
|
|
|
|
|
abstract function get_link();
|
|
|
|
|
|
abstract function is_valid_link();
|
|
|
|
|
|
abstract function get_type_name();
|
|
|
|
|
|
|
|
|
|
|
|
// The following methods are already defined in GradebookItem,
|
|
|
|
|
|
// and must be implemented by the subclass as well !
|
|
|
|
|
|
// abstract function get_name();
|
|
|
|
|
|
// abstract function get_description();
|
|
|
|
|
|
// abstract function calc_score($stud_id = null);
|
|
|
|
|
|
|
|
|
|
|
|
abstract function needs_name_and_description();
|
|
|
|
|
|
abstract function needs_max();
|
|
|
|
|
|
abstract function needs_results();
|
|
|
|
|
|
abstract function is_allowed_to_change_name();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TRIVIAL FUNCTIONS - to be overwritten by subclass if needed
|
|
|
|
|
|
|
|
|
|
|
|
public function get_not_created_links()
|
|
|
|
|
|
{
|
|
|
|
|
|
return null;
|
|
|
|
|
|
}
|
|
|
|
|
|
public function get_all_links()
|
|
|
|
|
|
{
|
|
|
|
|
|
return null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function add_linked_data()
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function save_linked_data()
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function delete_linked_data()
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function set_name ($name)
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_description ($description)
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set_max ($max)
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function get_view_url ($stud_id)
|
|
|
|
|
|
{
|
|
|
|
|
|
return null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
?>
|