-
Notifications
You must be signed in to change notification settings - Fork 14
/
reflectivenotes.php
80 lines (72 loc) · 3.1 KB
/
reflectivenotes.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
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Add/edit users reflective notes per grade item
*
* @package report_myfeedback
* @copyright 2022 UCL
* @author Delvon Forrester <[email protected]>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require('../../config.php');
require_login();
require_once($CFG->dirroot . '/report/myfeedback/lib.php');
$notename = optional_param('notename', '', PARAM_NOTAGS);
$gradeid = optional_param('gradeid', 0, PARAM_INT);
$userid = optional_param('userid', 0, PARAM_INT);
$instance = optional_param('instance1', 0, PARAM_INT);
if ($USER->id != $userid) {
redirect(new moodle_url('/report/myfeedback/index.php', ['userid' => $USER->id]),
get_string('usernotavailable', 'report_myfeedback'),
null,
\core\output\notification::NOTIFY_ERROR);
}
if (!empty($notename) && $gradeid && $userid) {
$reflectivenotes = strip_tags($notename, '<br>');
$now = time();
$sql = "SELECT notes FROM {report_myfeedback}
WHERE userid=? AND gradeitemid=? AND iteminstance=?";
$sql1 = "UPDATE {report_myfeedback}
SET modifierid=?, notes=?, timemodified=?
WHERE userid=? AND gradeitemid=? AND iteminstance=?";
$sql2 = "INSERT INTO {report_myfeedback}
(userid, gradeitemid, modifierid, iteminstance, notes, timemodified)
VALUES (?, ?, ?, ?, ?, ?)";
$params = [$userid, $gradeid, $instance];
$params1 = [$USER->id, $reflectivenotes, $now, $userid, $gradeid, $instance];
$params2 = [$userid, $gradeid, $USER->id, $instance, $reflectivenotes, $now];
$usernotes = $DB->get_record_sql($sql, $params);
$event = \report_myfeedback\event\myfeedbackreport_addnotes::create(
['context' => context_user::instance($userid), 'relateduserid' => $userid]
);
if ($usernotes) {
$DB->execute($sql1, $params1);
echo get_string('updatesuccessful', 'report_myfeedback');
$event = \report_myfeedback\event\myfeedbackreport_updatenotes::create(
['context' => context_user::instance($userid), 'relateduserid' => $userid]
);
} else {
$DB->execute($sql2, $params2);
echo get_string('insertsuccessful', 'report_myfeedback');
}
$event->trigger();
redirect(new \moodle_url('/report/myfeedback/index.php',
[
'userid' => $userid,
'currenttab' => 'feedback',
]
));
}