PluginProbe ʕ •ᴥ•ʔ
Tutor LMS – eLearning and online course solution / 1.6.6
Tutor LMS – eLearning and online course solution v1.6.6
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 / Students_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_Settings_Tabs.php 5 years ago Course_Widget.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 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
Students_List.php
131 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 Students_List extends \Tutor_List_Table {
12
13 function __construct(){
14 global $status, $page;
15
16 //Set parent defaults
17 parent::__construct( array(
18 'singular' => 'student', //singular name of the listed records
19 'plural' => 'students', //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 'user_email':
27 case 'display_name':
28 return $item->$column_name;
29 default:
30 return print_r($item,true); //Show the whole array for troubleshooting purposes
31 }
32 }
33
34 /**
35 * @param $item
36 *
37 * Completed Course by User
38 */
39 function column_completed_course($item){
40 $user_id = $item->ID;
41
42 $courses = tutor_utils()->get_courses_by_user($user_id);
43 if ($courses && is_array($courses->posts) && count($courses->posts)){
44 foreach ($courses->posts as $course){
45 echo '<a href="'.get_the_permalink($course->ID).'" target="_blank">'.$course->post_title.'</a>';
46 }
47 }
48 }
49
50 /*
51 function column_display_name($item){
52 //Build row actions
53 $actions = array(
54 'edit' => sprintf('<a href="?page=%s&action=%s&student=%s">Edit</a>',$_REQUEST['page'],'edit',$item->ID),
55 'delete' => sprintf('<a href="?page=%s&action=%s&student=%s">Delete</a>',$_REQUEST['page'],'delete',$item->ID),
56 );
57
58 //Return the title contents
59 return sprintf('%1$s <span style="color:silver">(id:%2$s)</span>%3$s',
60 $item->display_name,
61 $item->ID,
62 $this->row_actions($actions)
63 );
64 }*/
65
66 function column_cb($item){
67 return sprintf(
68 '<input type="checkbox" name="%1$s[]" value="%2$s" />',
69 /*$1%s*/ $this->_args['singular'], //Let's simply repurpose the table's singular label ("student")
70 /*$2%s*/ $item->ID //The value of the checkbox should be the record's id
71 );
72 }
73
74 function get_columns(){
75 $columns = array(
76 'cb' => '<input type="checkbox" />', //Render a checkbox instead of text
77 'display_name' => __('Name', 'tutor'),
78 'user_email' => __('E-Mail', 'tutor'),
79 'completed_course' => __('Completed Course', 'tutor'),
80 );
81 return $columns;
82 }
83
84 function get_sortable_columns() {
85 $sortable_columns = array(
86 //'display_name' => array('title',false), //true means it's already sorted
87 );
88 return $sortable_columns;
89 }
90
91 function get_bulk_actions() {
92 $actions = array(
93 //'delete' => 'Delete'
94 );
95 return $actions;
96 }
97
98 function process_bulk_action() {
99 //Detect when a bulk action is being triggered...
100 if( 'delete'===$this->current_action() ) {
101 wp_die('Items deleted (or they would be if we had items to delete)!');
102 }
103 }
104
105 function prepare_items() {
106 $per_page = 20;
107
108 $search_term = '';
109 if (isset($_REQUEST['s'])){
110 $search_term = sanitize_text_field($_REQUEST['s']);
111 }
112
113 $columns = $this->get_columns();
114 $hidden = array();
115 $sortable = $this->get_sortable_columns();
116
117 $this->_column_headers = array($columns, $hidden, $sortable);
118 //$this->process_bulk_action();
119
120 $current_page = $this->get_pagenum();
121
122 $total_items = tutor_utils()->get_total_students($search_term);
123 $this->items = tutor_utils()->get_students(($current_page-1)*$per_page, $per_page, $search_term);;
124
125 $this->set_pagination_args( array(
126 'total_items' => $total_items, //WE have to calculate the total number of items
127 'per_page' => $per_page, //WE have to determine how many items to show on a page
128 'total_pages' => ceil($total_items/$per_page) //WE have to calculate the total number of pages
129 ) );
130 }
131 }