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