-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathblock_cegep_enrolprogram_form.php
89 lines (63 loc) · 2.9 KB
/
block_cegep_enrolprogram_form.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
require_once($CFG->libdir.'/formslib.php');
class cegep_enrolprogram_form extends moodleform {
function definition() {
$mform =& $this->_form;
$programs = self::get_programs();
$mform->addElement('select', 'program_id', get_string('program','block_cegep'), $programs);
$mform->setType('program_id', PARAM_TEXT);
$mform->addRule('program_id', get_string('specifyprogram','block_cegep'), 'required');
$mform->addElement('select', 'program_year', get_string('programyear','block_cegep'), array('1' => get_string('programyear1', 'block_cegep'), '2' => get_string('programyear2', 'block_cegep'), '3' => get_string('programyear3', 'block_cegep')));
$mform->setType('program_year', PARAM_INT);
$mform->addRule('program_year', get_string('specifyprogramyear','block_cegep'), 'required');
$this->add_action_buttons();
}
function validation($data, $files) {
$errors = parent::validation($data, $files);
if (empty($data['program_id'])) {
$errors['program_id'] = get_string('programinvalid','block_cegep');
}
if (empty($data['program_year'])) {
$errors['program_year'] = get_string('programyearinvalid','block_cegep');
}
if (!empty($errors)) {
return $errors;
}
$program_idyear = $data['program_id'] . '_' . $data['program_year'];
// Verify if the program isn't already enrolled in this course
if (self::validate_program_enrolled($program_idyear)) {
$errors['program_id'] = get_string('programalreadyenrolled','block_cegep');
}
return $errors;
}
private function get_programs() {
global $sisdb;
$select = "SELECT * FROM `program` ORDER BY `id`";
$programs_rs = $sisdb->Execute($select);
if (!$programs_rs) {
trigger_error($enroldb->ErrorMsg() .' STATEMENT: '. $select, E_USER_ERROR);
return false;
}
$program_id = '';
$programs = array();
while (!$programs_rs->EOF) {
$program_id = $programs_rs->fields['id'];
$program_title = $programs_rs->fields['title'];
$programs[$program_id] = "$program_id - $program_title";
$programs_rs->MoveNext();
}
return $programs;
}
private function validate_program_enrolled($program_idyear) {
global $CFG, $COURSE, $enroldb;
$select = "SELECT COUNT(`program_idyear`) AS num FROM `$CFG->enrol_remoteenroltable` WHERE `$CFG->enrol_remotecoursefield` = '$COURSE->idnumber' AND `program_idyear` = '$program_idyear' LIMIT 1";
$result = $enroldb->Execute($select);
if (!$result) {
trigger_error($enroldb->ErrorMsg() .' STATEMENT: '. $select, E_USER_ERROR);
return false;
}
else
return $result->fields['num'];
}
}
?>