PluginProbe ʕ •ᴥ•ʔ
Tutor LMS – eLearning and online course solution / 1.8.7
Tutor LMS – eLearning and online course solution v1.8.7
3.9.14 3.9.13 3.9.12 3.9.11 trunk 1.0.0 1.0.0-alpha 1.0.1 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.0.7 1.0.8 1.0.9 1.1.0 1.1.1 1.2.0 1.2.1 1.2.11 1.2.12 1.2.13 1.2.20 1.3.0 1.3.1 1.3.2 1.3.3 1.3.4 1.3.5 1.3.6 1.3.7 1.3.8 1.3.9 1.4.0 1.4.1 1.4.2 1.4.3 1.4.4 1.4.5 1.4.6 1.4.7 1.4.8 1.4.9 1.5.0 1.5.1 1.5.2 1.5.3 1.5.4 1.5.5 1.5.6 1.5.7 1.5.8 1.5.9 1.6.0 1.6.1 1.6.2 1.6.3 1.6.4 1.6.5 1.6.6 1.6.7 1.6.8 1.6.9 1.7.0 1.7.1 1.7.2 1.7.3 1.7.4 1.7.5 1.7.6 1.7.7 1.7.8 1.7.9 1.8.0 1.8.1 1.8.10 1.8.2 1.8.3 1.8.4 1.8.5 1.8.6 1.8.7 1.8.8 1.8.9 1.9.0 1.9.1 1.9.10 1.9.11 1.9.12 1.9.13 1.9.14 1.9.15 1.9.16 1.9.2 1.9.3 1.9.4 1.9.5 1.9.6 1.9.7 1.9.8 1.9.9 2.0.0 2.0.1 2.0.10 2.0.2 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7 2.0.8 2.0.9 2.1.0 2.1.1 2.1.10 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8 2.1.9 2.2.0 2.2.1 2.2.2 2.2.3 2.2.4 2.3.0 2.4.0 2.5.0 2.6.0 2.6.1 2.6.2 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.7.6 2.7.7 3.0.0 3.0.1 3.0.2 3.1.0 3.2.0 3.2.1 3.2.2 3.2.3 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.5.0 3.6.0 3.6.1 3.6.2 3.6.3 3.6.4 3.7.0 3.7.1 3.7.2 3.7.3 3.7.4 3.8.0 3.8.1 3.8.2 3.8.3 3.9.0 3.9.1 3.9.10 3.9.2 3.9.3 3.9.4 3.9.5 3.9.6 3.9.7 3.9.8 3.9.9
tutor / classes / Quiz_Attempts_List.php
tutor / classes Last commit date
Addons.php 5 years ago Admin.php 5 years ago Ajax.php 5 years ago Assets.php 5 years ago Course.php 5 years ago Course_Filter.php 5 years ago Course_Settings_Tabs.php 5 years ago Course_Widget.php 5 years ago Custom_Validation.php 5 years ago Dashboard.php 5 years ago Email.php 5 years ago FormHandler.php 5 years ago Frontend.php 5 years ago Gutenberg.php 5 years ago Instructor.php 5 years ago Instructors_List.php 5 years ago Lesson.php 5 years ago Options.php 5 years ago Post_types.php 5 years ago Private_Course_Access.php 5 years ago Q_and_A.php 5 years ago Question_Answers_List.php 5 years ago Quiz.php 5 years ago Quiz_Attempts_List.php 5 years ago RestAPI.php 5 years ago Rewrite_Rules.php 5 years ago Shortcode.php 5 years ago Student.php 5 years ago Students_List.php 5 years ago Taxonomies.php 5 years ago Template.php 5 years ago Theme_Compatibility.php 5 years ago Tools.php 5 years ago Tutor.php 5 years ago TutorEDD.php 5 years ago Tutor_Base.php 5 years ago Tutor_List_Table.php 5 years ago Tutor_Setup.php 5 years ago Upgrader.php 5 years ago User.php 5 years ago Utils.php 5 years ago Video_Stream.php 5 years ago Withdraw.php 5 years ago Withdraw_Requests_List.php 5 years ago WooCommerce.php 5 years ago
Quiz_Attempts_List.php
204 lines
1 <?php
2 namespace TUTOR;
3
4 if ( ! defined( 'ABSPATH' ) )
5 exit;
6
7 if (! class_exists('Tutor_List_Table')){
8 include_once tutor()->path.'classes/Tutor_List_Table.php';
9 }
10
11 class Quiz_Attempts_List extends \Tutor_List_Table {
12
13 function __construct(){
14 global $status, $page;
15
16 //Set parent defaults
17 parent::__construct( array(
18 'singular' => 'attempt', //singular name of the listed records
19 'plural' => 'attempts', //plural name of the listed records
20 'ajax' => false //does this table support ajax?
21 ) );
22 }
23
24 function column_default($item, $column_name){
25 switch($column_name){
26 case 'unknown_col':
27 return $item->$column_name;
28 default:
29 //return print_r($item,true); //Show the whole array for troubleshooting purposes
30 }
31 }
32
33 function column_student($item){
34 $actions = array();
35
36 $actions['answer'] = sprintf('<a href="?page=%s&sub_page=%s&attempt_id=%s">'.__('Review', 'tutor').'</a>',$_REQUEST['page'],'view_attempt',$item->attempt_id);
37 //$actions['delete'] = sprintf('<a href="?page=%s&action=%s&attempt_id=%s">Delete</a>',$_REQUEST['page'],'delete',$item->attempt_id);
38
39 $quiz_title = "<p><strong>{$item->display_name}</strong></p>";
40 $quiz_title .= "<p>{$item->user_email}</p>";
41
42 if ($item->attempt_ended_at){
43 $ended_ago_time = human_time_diff(strtotime($item->attempt_ended_at), tutor_time()).__(' ago', 'tutor');
44 $quiz_title .= "<span>{$ended_ago_time}</span>";
45 }
46
47 //Return the title contents
48 return sprintf('%1$s <span style="color:silver">(id:%2$s)</span>%3$s',
49 $quiz_title,
50 $item->attempt_id,
51 $this->row_actions($actions)
52 );
53 }
54
55 function column_quiz($item){
56 return $item->post_title;
57 }
58
59 function column_cb($item){
60 return sprintf(
61 '<input type="checkbox" name="%1$s[]" value="%2$s" />',
62 /*$1%s*/ $this->_args['singular'], //Let's simply repurpose the table's singular label ("instructor")
63 /*$2%s*/ $item->attempt_id //The value of the checkbox should be the record's id
64 );
65 }
66
67 function column_course($item) {
68 $quiz = tutor_utils()->get_course_by_quiz($item->quiz_id);
69
70 if ($quiz) {
71 $title = get_the_title( $quiz->ID );
72 return "<a href='" . admin_url( "post.php?post={$quiz->ID}&action=edit" ) . "'>{$title}</a>";
73 }
74 }
75
76 function column_total_questions($item) {
77 echo $item->total_questions;
78 }
79
80 function column_earned_marks($item){
81
82 if ($item->attempt_status === 'review_required'){
83 $output = '<span class="result-review-required">' . __('Under Review', 'tutor') . '</span>';
84 }else {
85
86 $pass_mark_percent = tutor_utils()->get_quiz_option($item->quiz_id, 'passing_grade', 0);
87 $earned_percentage = $item->earned_marks > 0 ? (number_format(($item->earned_marks * 100) / $item->total_marks)) : 0;
88
89 $output = $item->earned_marks . " out of {$item->total_marks} <br />";
90 $output .= "({$earned_percentage}%) pass ({$pass_mark_percent}%) <br />";
91
92 if ($earned_percentage >= $pass_mark_percent) {
93 $output .= '<span class="result-pass">' . __('Pass', 'tutor') . '</span>';
94 } else {
95 $output .= '<span class="result-fail">' . __('Fail', 'tutor') . '</span>';
96 }
97 }
98 return $output;
99 }
100
101 function column_attempt_status($item){
102 $status = ucwords(str_replace('quiz_', '', $item->attempt_status));
103
104 return "<span class='attempt-status-{$item->attempt_status}'>{$status}</span>";
105 }
106
107 function get_columns(){
108 $columns = array(
109 'cb' => '<input type="checkbox" />', //Render a checkbox instead of text
110 'student' => __('Students', 'tutor'),
111 'quiz' => __('Quiz', 'tutor'),
112 'course' => __('Course', 'tutor'),
113 'total_questions' => __('Total Questions', 'tutor'),
114 'earned_marks' => __('Earned Points', 'tutor'),
115 //'attempt_status' => __('Attempt Status', 'tutor'),
116 );
117 return $columns;
118 }
119
120 function get_sortable_columns() {
121 $sortable_columns = array(
122 //'display_name' => array('title',false), //true means it's already sorted
123 );
124 return $sortable_columns;
125 }
126
127 function get_bulk_actions() {
128 $actions = array(
129 'delete' => 'Delete'
130 );
131 return $actions;
132 }
133
134 function process_bulk_action() {
135 global $wpdb;
136
137 //Detect when a bulk action is being triggered...
138 if( 'delete' === $this->current_action() ) {
139 if ( empty($_GET['attempt']) || ! is_array($_GET['attempt'])){
140 return;
141 }
142
143 $attempt_ids = array_map('sanitize_text_field', $_GET['attempt']);
144 $attempt_ids = implode( ',', array_map( 'absint', $attempt_ids ) );
145
146 //Deleting attempt (comment), child attempt and attempt meta (comment meta)
147 $wpdb->query( "DELETE FROM {$wpdb->prefix}tutor_quiz_attempts WHERE attempt_id IN($attempt_ids)" );
148 $wpdb->query( "DELETE FROM {$wpdb->prefix}tutor_quiz_attempt_answers WHERE quiz_attempt_id IN($attempt_ids)" );
149 }
150 }
151
152 function prepare_items() {
153 global $wpdb;
154
155 $per_page = 20;
156 $search_term = '';
157 if (isset($_REQUEST['s'])){
158 $search_term = sanitize_text_field($_REQUEST['s']);
159 }
160
161 $columns = $this->get_columns();
162 $hidden = array();
163 $sortable = $this->get_sortable_columns();
164
165 $this->_column_headers = array($columns, $hidden, $sortable);
166 $this->process_bulk_action();
167
168 $current_page = $this->get_pagenum();
169
170 $total_items = 0;
171 $this->items = array();
172
173 if (current_user_can('administrator')) {
174 $total_items = tutor_utils()->get_total_quiz_attempts( $search_term );
175 $this->items = tutor_utils()->get_quiz_attempts( ( $current_page - 1 ) * $per_page, $per_page, $search_term );
176 }elseif (current_user_can('tutor_instructor')){
177 /**
178 * Instructors course specific quiz attempts
179 */
180 $user_id = get_current_user_id();
181 $get_assigned_courses_ids = $wpdb->get_col($wpdb->prepare("SELECT meta_value from {$wpdb->usermeta} WHERE meta_key = '_tutor_instructor_course_id' AND user_id = %d", $user_id));
182
183 $custom_author_query = "AND {$wpdb->posts}.post_author = {$user_id}";
184 if (is_array($get_assigned_courses_ids) && count($get_assigned_courses_ids)){
185 $in_query_pre = implode(',', $get_assigned_courses_ids);
186 $custom_author_query = " AND ( {$wpdb->posts}.post_author = {$user_id} OR {$wpdb->posts}.ID IN({$in_query_pre}) ) ";
187 }
188 $course_post_type = tutor()->course_post_type;
189 $get_course_ids = $wpdb->get_col("SELECT ID from {$wpdb->posts} where post_type = '{$course_post_type}' $custom_author_query ; ");
190
191 if (is_array($get_course_ids) && count($get_course_ids)){
192 $total_items = tutor_utils()->get_total_quiz_attempts_by_course_ids($get_course_ids, $search_term );
193 $this->items = tutor_utils()->get_quiz_attempts_by_course_ids(( $current_page - 1 ) * $per_page, $per_page, $get_course_ids, $search_term );
194 }
195
196 }
197
198 $this->set_pagination_args( array(
199 'total_items' => $total_items,
200 'per_page' => $per_page,
201 'total_pages' => ceil($total_items/$per_page)
202 ) );
203 }
204 }