Add migrations, remove c_survey.author use resourceNode.author instead.pull/3844/head
parent
307ff058e8
commit
7b6b244b4f
@ -1,125 +0,0 @@ |
|||||||
<?php |
|
||||||
/* For licensing terms, see /license.txt */ |
|
||||||
|
|
||||||
/** |
|
||||||
* Manage the "versioning" of a conditional survey. |
|
||||||
*/ |
|
||||||
class SurveyTree |
|
||||||
{ |
|
||||||
public $surveylist; |
|
||||||
public $plainsurveylist; |
|
||||||
public $numbersurveys; |
|
||||||
|
|
||||||
/** |
|
||||||
* Sets the surveylist and the plainsurveylist. |
|
||||||
*/ |
|
||||||
public function __construct() |
|
||||||
{ |
|
||||||
// Database table definitions |
|
||||||
$table_survey = Database::get_course_table(TABLE_SURVEY); |
|
||||||
$table_survey_question = Database::get_course_table(TABLE_SURVEY_QUESTION); |
|
||||||
$table_user = Database::get_main_table(TABLE_MAIN_USER); |
|
||||||
|
|
||||||
// searching |
|
||||||
$search_restriction = SurveyUtil::survey_search_restriction(); |
|
||||||
if ($search_restriction) { |
|
||||||
$search_restriction = ' AND '.$search_restriction; |
|
||||||
} |
|
||||||
|
|
||||||
$course_id = api_get_course_int_id(); |
|
||||||
|
|
||||||
$sql = "SELECT |
|
||||||
survey.iid survey_id, |
|
||||||
survey.parent_id, |
|
||||||
survey_version, |
|
||||||
survey.code as name |
|
||||||
FROM $table_survey survey |
|
||||||
LEFT JOIN $table_survey_question survey_question |
|
||||||
ON survey.iid = survey_question.survey_id , $table_user user |
|
||||||
WHERE |
|
||||||
survey.c_id = $course_id AND |
|
||||||
survey_question.c_id = $course_id AND |
|
||||||
survey.author = user.id |
|
||||||
GROUP BY survey.iid"; |
|
||||||
|
|
||||||
$res = Database::query($sql); |
|
||||||
$refs = []; |
|
||||||
$list = []; |
|
||||||
$plain_array = []; |
|
||||||
|
|
||||||
while ($survey = Database::fetch_array($res, 'ASSOC')) { |
|
||||||
$plain_array[$survey['survey_id']] = $survey; |
|
||||||
$surveys_parents[] = $survey['survey_version']; |
|
||||||
$thisref = &$refs[$survey['survey_id']]; |
|
||||||
$thisref['parent_id'] = $survey['parent_id']; |
|
||||||
$thisref['name'] = $survey['name']; |
|
||||||
$thisref['id'] = $survey['survey_id']; |
|
||||||
$thisref['survey_version'] = $survey['survey_version']; |
|
||||||
if (0 == $survey['parent_id']) { |
|
||||||
$list[$survey['survey_id']] = &$thisref; |
|
||||||
} else { |
|
||||||
$refs[$survey['parent_id']]['children'][$survey['survey_id']] = &$thisref; |
|
||||||
} |
|
||||||
} |
|
||||||
$this->surveylist = $list; |
|
||||||
$this->plainsurveylist = $plain_array; |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* This function gets the parent id of a survey. |
|
||||||
* |
|
||||||
* @param int $id survey id |
|
||||||
* |
|
||||||
* @return int survey parent id |
|
||||||
* |
|
||||||
* @author Julio Montoya <gugli100@gmail.com>, Dokeos |
|
||||||
* |
|
||||||
* @version September 2008 |
|
||||||
*/ |
|
||||||
public function getParentId($id) |
|
||||||
{ |
|
||||||
$node = $this->plainsurveylist[$id]; |
|
||||||
if (is_array($node) && !empty($node['parent_id'])) { |
|
||||||
return $node['parent_id']; |
|
||||||
} |
|
||||||
|
|
||||||
return -1; |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* This function creates a list of all surveys id. |
|
||||||
* |
|
||||||
* @param array $list of nodes |
|
||||||
* |
|
||||||
* @return array with the structure survey_id => survey_name |
|
||||||
* |
|
||||||
* @author Julio Montoya <gugli100@gmail.com> |
|
||||||
* |
|
||||||
* @version September 2008 |
|
||||||
*/ |
|
||||||
public function createList($list) |
|
||||||
{ |
|
||||||
$result = []; |
|
||||||
if (is_array($list)) { |
|
||||||
foreach ($list as $key => $node) { |
|
||||||
if (isset($node['children']) && is_array($node['children'])) { |
|
||||||
$result[$key] = $node['name']; |
|
||||||
$re = self::createList($node['children']); |
|
||||||
if (!empty($re)) { |
|
||||||
if (is_array($re)) { |
|
||||||
foreach ($re as $key => $r) { |
|
||||||
$result[$key] = ''.$r; |
|
||||||
} |
|
||||||
} else { |
|
||||||
$result[] = $re; |
|
||||||
} |
|
||||||
} |
|
||||||
} else { |
|
||||||
$result[$key] = $node['name']; |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
return $result; |
|
||||||
} |
|
||||||
} |
|
||||||
Loading…
Reference in new issue