diff --git a/changelog.txt b/changelog.txt index 2efdddb7ee..23cec27dd1 100755 --- a/changelog.txt +++ b/changelog.txt @@ -1,5 +1,12 @@ *** Sensei Changelog *** +2014.06.30 - version 1.6.1 + * Fix - Making sure Learner Management page shows for users with 'manage_sensei_grades' capability + * Fix - Fixing bug that prevented all email notifications from being deactivated + * Fix - Fixing lesson order in single lesson next/previous lesson navigation + * Fix - Ensuring that modules display on single course page for courses with prerequisites + * Fix - Making sure learner management user search works without WooCommerce activated + 2014.06.25 - version 1.6.0 * New - Comprehensive question bank functionality including question categories, the ability to re-use questions in multiple quizzes and bulk adding questions from a category * New - New Learner Management dashboard that allows administrators to add/remove learners to/from any course or lesson diff --git a/classes/class-woothemes-sensei-learners.php b/classes/class-woothemes-sensei-learners.php index 46496d09bf..1bf532f395 100755 --- a/classes/class-woothemes-sensei-learners.php +++ b/classes/class-woothemes-sensei-learners.php @@ -84,7 +84,7 @@ public function __construct ( $file ) { public function learners_admin_menu() { global $menu; - if ( current_user_can( 'manage_sensei' ) ) { + if ( current_user_can( 'manage_sensei_grades' ) ) { $learners_page = add_submenu_page( 'sensei', $this->name, $this->name, 'manage_sensei_grades', $this->page_slug, array( $this, 'learners_page' ) ); } @@ -324,7 +324,7 @@ public function json_search_users() { check_ajax_referer( 'search-users', 'security' ); - $term = wc_clean( stripslashes( $_GET['term'] ) ); + $term = sanitize_text_field( stripslashes( $_GET['term'] ) ); if ( empty( $term ) ) { die(); diff --git a/classes/class-woothemes-sensei-settings-api.php b/classes/class-woothemes-sensei-settings-api.php index 587d6f7345..47a1020a6f 100755 --- a/classes/class-woothemes-sensei-settings-api.php +++ b/classes/class-woothemes-sensei-settings-api.php @@ -660,6 +660,7 @@ public function validate_fields ( $input ) { foreach ( $this->fields as $k => $v ) { // Make sure checkboxes are present even when false. if ( $v['type'] == 'checkbox' && ! isset( $input[$k] ) ) { $input[$k] = false; } + if ( $v['type'] == 'multicheck' && ! isset( $input[$k] ) ) { $input[$k] = false; } if ( isset( $input[$k] ) ) { // Perform checks on required fields. diff --git a/inc/woothemes-sensei-template.php b/inc/woothemes-sensei-template.php index ef193cc05b..294adef314 100755 --- a/inc/woothemes-sensei-template.php +++ b/inc/woothemes-sensei-template.php @@ -502,23 +502,86 @@ function sensei_get_prev_next_lessons( $lesson_id = 0 ) { if ( 0 < $lesson_id ) { // Get the List of Lessons in the Course $lesson_course_id = get_post_meta( $lesson_id, '_lesson_course', true ); - $course_lessons = $woothemes_sensei->frontend->course->course_lessons( $lesson_course_id ); - // Index the Lessons - if ( 0 < count( $course_lessons ) ) { + $all_lessons = array(); + if( class_exists( 'Sensei_Modules' ) ) { + global $sensei_modules; + + $modules = $sensei_modules->get_course_modules( intval( $lesson_course_id ) ); + + foreach( $modules as $module ) { + + $args = array( + 'post_type' => 'lesson', + 'post_status' => 'publish', + 'posts_per_page' => -1, + 'meta_query' => array( + array( + 'key' => '_lesson_course', + 'value' => intval( $lesson_course_id ), + 'compare' => '=' + ) + ), + 'tax_query' => array( + array( + 'taxonomy' => $sensei_modules->taxonomy, + 'field' => 'id', + 'terms' => intval( $module->term_id ) + ) + ), + 'meta_key' => '_order_module_' . $module->term_id, + 'orderby' => 'meta_value_num date', + 'order' => 'ASC', + 'suppress_filters' => 0 + ); + + $lessons = get_posts( $args ); + if ( 0 < count( $lessons ) ) { + foreach ($lessons as $lesson_item){ + $all_lessons[] = $lesson_item->ID; + } // End For Loop + } // End If Statement + } + } + + $args = array( + 'post_type' => 'lesson', + 'posts_per_page' => -1, + 'suppress_filters' => 0, + 'meta_key' => '_order_' . $lesson_course_id, + 'orderby' => 'meta_value_num date', + 'order' => 'ASC', + 'meta_query' => array( + array( + 'key' => '_lesson_course', + 'value' => intval( $lesson_course_id ), + ), + ), + 'post__not_in' => $all_lessons, + ); + + $other_lessons = get_posts( $args ); + if ( 0 < count( $other_lessons ) ) { + foreach ($other_lessons as $lesson_item){ + $all_lessons[] = $lesson_item->ID; + } // End For Loop + } // End If Statement + + if ( 0 < count( $all_lessons ) ) { $found_index = false; - foreach ($course_lessons as $lesson_item){ + foreach ( $all_lessons as $lesson ){ if ( $found_index && $return_values['next_lesson'] == 0 ) { - $return_values['next_lesson'] = $lesson_item->ID; + $return_values['next_lesson'] = $lesson; } // End If Statement - if ( $lesson_item->ID == $lesson_id ) { + if ( $lesson == $lesson_id ) { // Is the current post $found_index = true; } // End If Statement if ( !$found_index ) { - $return_values['prev_lesson'] = $lesson_item->ID; + $return_values['prev_lesson'] = $lesson; } // End If Statement } // End For Loop } // End If Statement + } // End If Statement return $return_values; } // End sensei_get_prev_next_lessons() diff --git a/templates/content-no-permissions.php b/templates/content-no-permissions.php index 1a10b74f22..bdffdb353d 100644 --- a/templates/content-no-permissions.php +++ b/templates/content-no-permissions.php @@ -33,7 +33,7 @@ - + diff --git a/woothemes-sensei.php b/woothemes-sensei.php index f7add700b4..ed9bba78b7 100644 --- a/woothemes-sensei.php +++ b/woothemes-sensei.php @@ -3,10 +3,12 @@ Plugin Name: Sensei Plugin URI: http://www.woothemes.com/products/sensei/ Description: A course management plugin that offers the smoothest platform for helping you teach anything. -Version: 1.6.0 +Version: 1.6.1 Author: WooThemes Author URI: http://www.woothemes.com/ License: GPL version 2 or later - http://www.gnu.org/licenses/old-licenses/gpl-2.0.html +Requires at least: 3.9 +Tested up to: 3.9.1 */ /* Copyright 2013 WooThemes (email : info@woothemes.com) @@ -35,7 +37,7 @@ global $woothemes_sensei; $woothemes_sensei = new WooThemes_Sensei( __FILE__ ); - $woothemes_sensei->version = '1.6.0'; + $woothemes_sensei->version = '1.6.1'; /** * Plugin updates