You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							365 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
	
	
							365 lines
						
					
					
						
							13 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
 | 
						|
/**
 | 
						|
 * List sessions in an efficient and usable way.
 | 
						|
 */
 | 
						|
$cidReset = true;
 | 
						|
 | 
						|
require_once __DIR__.'/../inc/global.inc.php';
 | 
						|
$this_section = SECTION_PLATFORM_ADMIN;
 | 
						|
 | 
						|
SessionManager::protectSession(null, false);
 | 
						|
 | 
						|
// Add the JS needed to use the jqgrid
 | 
						|
$htmlHeadXtra[] = api_get_jqgrid_js();
 | 
						|
 | 
						|
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : null;
 | 
						|
$idChecked = isset($_REQUEST['idChecked']) ? $_REQUEST['idChecked'] : null;
 | 
						|
$listType = isset($_REQUEST['list_type']) ? Security::remove_XSS($_REQUEST['list_type']) : SessionManager::getDefaultSessionTab();
 | 
						|
 | 
						|
$tool_name = get_lang('SessionList');
 | 
						|
Display::display_header($tool_name);
 | 
						|
$courseId = isset($_GET['course_id']) ? $_GET['course_id'] : null;
 | 
						|
 | 
						|
$sessionFilter = new FormValidator(
 | 
						|
    'course_filter',
 | 
						|
    'get',
 | 
						|
    '',
 | 
						|
    '',
 | 
						|
    [],
 | 
						|
    FormValidator::LAYOUT_INLINE
 | 
						|
);
 | 
						|
$courseSelect = $sessionFilter->addElement(
 | 
						|
    'select_ajax',
 | 
						|
    'course_name',
 | 
						|
    get_lang('SearchCourse'),
 | 
						|
    null,
 | 
						|
    ['url' => api_get_path(WEB_AJAX_PATH).'course.ajax.php?a=search_course']
 | 
						|
);
 | 
						|
 | 
						|
if (!empty($courseId)) {
 | 
						|
    $courseInfo = api_get_course_info_by_id($courseId);
 | 
						|
    $parents = CourseCategory::getParentsToString($courseInfo['categoryCode']);
 | 
						|
    $courseSelect->addOption($parents.$courseInfo['title'], $courseInfo['code'], ['selected' => 'selected']);
 | 
						|
}
 | 
						|
 | 
						|
$url = api_get_self();
 | 
						|
$actions = '
 | 
						|
<script>
 | 
						|
$(function() {
 | 
						|
    $("#course_name").on("change", function() {
 | 
						|
       var courseId = $(this).val();
 | 
						|
       if (!courseId) {
 | 
						|
        return;
 | 
						|
       }
 | 
						|
       window.location = "'.$url.'?course_id="+courseId;
 | 
						|
    });
 | 
						|
});
 | 
						|
</script>';
 | 
						|
 | 
						|
// jqgrid will use this URL to do the selects
 | 
						|
if (!empty($courseId)) {
 | 
						|
    $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions&course_id='.$courseId;
 | 
						|
} else {
 | 
						|
    $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions';
 | 
						|
}
 | 
						|
 | 
						|
if (isset($_REQUEST['keyword'])) {
 | 
						|
    //Begin with see the searchOper param
 | 
						|
    $filter = new stdClass();
 | 
						|
    $filter->groupOp = 'OR';
 | 
						|
    $rule = new stdClass();
 | 
						|
    $rule->field = 'category_name';
 | 
						|
    $rule->op = 'in';
 | 
						|
    $rule->data = Security::remove_XSS($_REQUEST['keyword']);
 | 
						|
    $filter->rules[] = $rule;
 | 
						|
    $filter->groupOp = 'OR';
 | 
						|
 | 
						|
    $filter = json_encode($filter);
 | 
						|
    $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions&_force_search=true&rows=20&page=1&sidx=&sord=asc&filters='.$filter.'&searchField=s.name&searchString='.Security::remove_XSS($_REQUEST['keyword']).'&searchOper=in';
 | 
						|
}
 | 
						|
 | 
						|
if (isset($_REQUEST['id_category'])) {
 | 
						|
    $sessionCategory = SessionManager::get_session_category($_REQUEST['id_category']);
 | 
						|
    if (!empty($sessionCategory)) {
 | 
						|
        //Begin with see the searchOper param
 | 
						|
        $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions&_force_search=true&rows=20&page=1&sidx=&sord=asc&filters=&searchField=sc.name&searchString='.Security::remove_XSS($sessionCategory['name']).'&searchOper=in';
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
$url .= '&list_type='.$listType;
 | 
						|
$result = SessionManager::getGridColumns($listType);
 | 
						|
 | 
						|
$columns = $result['columns'];
 | 
						|
$column_model = $result['column_model'];
 | 
						|
 | 
						|
// Autowidth
 | 
						|
$extra_params['autowidth'] = 'true';
 | 
						|
 | 
						|
// height auto
 | 
						|
$extra_params['height'] = 'auto';
 | 
						|
 | 
						|
// Custom params
 | 
						|
$extra_params['sortname'] = 'display_end_date';
 | 
						|
$extra_params['sortorder'] = 'desc';
 | 
						|
 | 
						|
if (!isset($_GET['keyword'])) {
 | 
						|
    $extra_params['postData'] = [
 | 
						|
        'filters' => [
 | 
						|
            'groupOp' => 'AND',
 | 
						|
            'rules' => $result['rules'],
 | 
						|
        ],
 | 
						|
    ];
 | 
						|
}
 | 
						|
 | 
						|
$hideSearch = api_get_configuration_value('hide_search_form_in_session_list');
 | 
						|
 | 
						|
//With this function we can add actions to the jgrid (edit, delete, etc)
 | 
						|
$action_links = 'function action_formatter(cellvalue, options, rowObject) {
 | 
						|
     return \'<a href="session_edit.php?page=resume_session.php&id=\'+options.rowId+\'">'.
 | 
						|
    Display::return_icon('edit.png', get_lang('Edit'), '', ICON_SIZE_SMALL).'</a>'.
 | 
						|
    ' <a href="add_users_to_session.php?page=session_list.php&id_session=\'+options.rowId+\'">'.
 | 
						|
    Display::return_icon('user_subscribe_session.png', get_lang('SubscribeUsersToSession'), '', ICON_SIZE_SMALL).'</a>'.
 | 
						|
    ' <a href="add_courses_to_session.php?page=session_list.php&id_session=\'+options.rowId+\'">'.
 | 
						|
    Display::return_icon('courses_to_session.png', get_lang('SubscribeCoursesToSession'), '', ICON_SIZE_SMALL).'</a>'.
 | 
						|
    ' <a onclick="javascript:if(!confirm('."\'".addslashes(api_htmlentities(get_lang("ConfirmYourChoice"), ENT_QUOTES))."\'".')) return false;" href="session_list.php?list_type='.$listType.'&action=copy&idChecked=\'+options.rowId+\'">'.
 | 
						|
    Display::return_icon('copy.png', get_lang('Copy'), '', ICON_SIZE_SMALL).'</a>'.
 | 
						|
    ' <a onclick="javascript:if(!confirm('."\'".addslashes(api_htmlentities(get_lang("ConfirmYourChoice"), ENT_QUOTES))."\'".')) return false;" href="session_list.php?list_type='.$listType.'&action=delete&idChecked=\'+options.rowId+\'">'.
 | 
						|
    Display::return_icon('delete.png', get_lang('Delete'), '', ICON_SIZE_SMALL).'</a>'.
 | 
						|
    '\';
 | 
						|
}';
 | 
						|
 | 
						|
$urlAjaxExtraField = api_get_path(WEB_AJAX_PATH).'extra_field.ajax.php?1=1';
 | 
						|
$allowOrder = api_get_configuration_value('session_list_order');
 | 
						|
$orderUrl = api_get_path(WEB_AJAX_PATH).'session.ajax.php?a=order';
 | 
						|
 | 
						|
?>
 | 
						|
    <script>
 | 
						|
        function setSearchSelect(columnName) {
 | 
						|
            $("#sessions").jqGrid('setColProp', columnName, {});
 | 
						|
        }
 | 
						|
        var added_cols = [];
 | 
						|
        var original_cols = [];
 | 
						|
 | 
						|
        function clean_cols(grid, added_cols) {
 | 
						|
            // Cleaning
 | 
						|
            for (key in added_cols) {
 | 
						|
                grid.hideCol(key);
 | 
						|
            }
 | 
						|
            grid.showCol('name');
 | 
						|
            grid.showCol('display_start_date');
 | 
						|
            grid.showCol('display_end_date');
 | 
						|
            grid.showCol('course_title');
 | 
						|
        }
 | 
						|
 | 
						|
        function show_cols(grid, added_cols) {
 | 
						|
            grid.showCol('name').trigger('reloadGrid');
 | 
						|
            for (key in added_cols) {
 | 
						|
                grid.showCol(key);
 | 
						|
            };
 | 
						|
        }
 | 
						|
 | 
						|
        var second_filters = [];
 | 
						|
 | 
						|
        $(function() {
 | 
						|
            date_pick_today = function(elem) {
 | 
						|
                $(elem).datetimepicker({dateFormat: "yy-mm-dd"});
 | 
						|
                $(elem).datetimepicker('setDate', (new Date()));
 | 
						|
            }
 | 
						|
            date_pick_one_month = function(elem) {
 | 
						|
                $(elem).datetimepicker({dateFormat: "yy-mm-dd"});
 | 
						|
                next_month = Date.today().next().month();
 | 
						|
                $(elem).datetimepicker('setDate', next_month);
 | 
						|
            }
 | 
						|
 | 
						|
            //Great hack
 | 
						|
            register_second_select = function(elem) {
 | 
						|
                second_filters[$(elem).val()] = $(elem);
 | 
						|
            }
 | 
						|
 | 
						|
            fill_second_select = function(elem) {
 | 
						|
                $(elem).on("change", function() {
 | 
						|
                    composed_id = $(this).val();
 | 
						|
                    field_id = composed_id.split("#")[0];
 | 
						|
                    id = composed_id.split("#")[1];
 | 
						|
 | 
						|
                    $.ajax({
 | 
						|
                        url: "<?php echo $urlAjaxExtraField; ?>&a=get_second_select_options",
 | 
						|
                        dataType: "json",
 | 
						|
                        data: "type=session&field_id="+field_id+"&option_value_id="+id,
 | 
						|
                        success: function(data) {
 | 
						|
                            my_select = second_filters[field_id];
 | 
						|
                            my_select.empty();
 | 
						|
                            $.each(data, function(index, value) {
 | 
						|
                                my_select.append($("<option/>", {
 | 
						|
                                    value: index,
 | 
						|
                                    text: value
 | 
						|
                                }));
 | 
						|
                            });
 | 
						|
                        }
 | 
						|
                    });
 | 
						|
                });
 | 
						|
            }
 | 
						|
 | 
						|
            <?php
 | 
						|
            echo Display::grid_js(
 | 
						|
                'sessions',
 | 
						|
                $url,
 | 
						|
                $columns,
 | 
						|
                $column_model,
 | 
						|
                $extra_params,
 | 
						|
                [],
 | 
						|
                $action_links,
 | 
						|
                true
 | 
						|
            );
 | 
						|
            ?>
 | 
						|
 | 
						|
            setSearchSelect("status");
 | 
						|
 | 
						|
            var grid = $("#sessions"),
 | 
						|
                prmSearch = {
 | 
						|
                    multipleSearch : true,
 | 
						|
                    overlay : false,
 | 
						|
                    width: 'auto',
 | 
						|
                    caption: '<?php echo addslashes(get_lang('Search')); ?>',
 | 
						|
                    formclass:'data_table',
 | 
						|
                    onSearch : function() {
 | 
						|
                        var postdata = grid.jqGrid('getGridParam', 'postData');
 | 
						|
 | 
						|
                        if (postdata && postdata.filters) {
 | 
						|
                            filters = jQuery.parseJSON(postdata.filters);
 | 
						|
                            clean_cols(grid, added_cols);
 | 
						|
                            added_cols = [];
 | 
						|
                            $.each(filters, function(key, value) {
 | 
						|
                                if (key == 'rules') {
 | 
						|
                                    $.each(value, function(subkey, subvalue) {
 | 
						|
                                        if (subvalue.data == undefined) {
 | 
						|
                                        }
 | 
						|
                                        added_cols[subvalue.field] = subvalue.field;
 | 
						|
                                    });
 | 
						|
                                }
 | 
						|
                            });
 | 
						|
                            show_cols(grid, added_cols);
 | 
						|
                        }
 | 
						|
                    },
 | 
						|
                    onReset: function() {
 | 
						|
                        clean_cols(grid, added_cols);
 | 
						|
                    }
 | 
						|
                };
 | 
						|
 | 
						|
            original_cols = grid.jqGrid('getGridParam', 'colModel');
 | 
						|
 | 
						|
            <?php if ($allowOrder) {
 | 
						|
                ?>
 | 
						|
            options = {
 | 
						|
                update: function (e, ui) {
 | 
						|
                    var rowNum = jQuery("#sessions").getGridParam('rowNum');
 | 
						|
                    var page = jQuery("#sessions").getGridParam('page');
 | 
						|
                    page = page - 1;
 | 
						|
                    var start = rowNum * page;
 | 
						|
                    var list = jQuery('#sessions').jqGrid('getRowData');
 | 
						|
                    var orderList = [];
 | 
						|
                    $(list).each(function(index, e) {
 | 
						|
                        index = index + start;
 | 
						|
                        orderList.push({'order':index, 'id': e.id});
 | 
						|
                    });
 | 
						|
                    orderList = JSON.stringify(orderList);
 | 
						|
                    $.get("<?php echo $orderUrl; ?>", "order="+orderList, function (result) {
 | 
						|
                    });
 | 
						|
                }
 | 
						|
            };
 | 
						|
 | 
						|
            // Sortable rows
 | 
						|
            grid.jqGrid('sortableRows', options);
 | 
						|
            <?php
 | 
						|
            } ?>
 | 
						|
 | 
						|
            grid.jqGrid('navGrid','#sessions_pager',
 | 
						|
                {edit:false,add:false,del:false},
 | 
						|
                {height:280,reloadAfterSubmit:false}, // edit options
 | 
						|
                {height:280,reloadAfterSubmit:false}, // add options
 | 
						|
                {reloadAfterSubmit:false},// del options
 | 
						|
                prmSearch
 | 
						|
            );
 | 
						|
 | 
						|
            <?php
 | 
						|
            // Create the searching dialog.
 | 
						|
            if ($hideSearch !== true) {
 | 
						|
                echo 'grid.searchGrid(prmSearch);';
 | 
						|
            }
 | 
						|
            ?>
 | 
						|
 | 
						|
            // Fixes search table.
 | 
						|
            var searchDialogAll = $("#fbox_"+grid[0].id);
 | 
						|
            searchDialogAll.addClass("table");
 | 
						|
            var searchDialog = $("#searchmodfbox_"+grid[0].id);
 | 
						|
            searchDialog.addClass("ui-jqgrid ui-widget ui-widget-content ui-corner-all");
 | 
						|
            searchDialog.css({position:"absolute", "z-index":"100", "float":"left", "top":"55%", "left" : "25%", "padding" : "5px", "border": "1px solid #CCC"})
 | 
						|
            var gbox = $("#gbox_"+grid[0].id);
 | 
						|
            gbox.before(searchDialog);
 | 
						|
            gbox.css({clear:"left"});
 | 
						|
 | 
						|
            // Select first elements by default
 | 
						|
            $('.input-elm').each(function(){
 | 
						|
                $(this).find('option:first').attr('selected', 'selected');
 | 
						|
            });
 | 
						|
 | 
						|
            $('.delete-rule').each(function(){
 | 
						|
                $(this).click(function(){
 | 
						|
                    $('.input-elm').each(function(){
 | 
						|
                        $(this).find('option:first').attr('selected', 'selected');
 | 
						|
                    });
 | 
						|
                });
 | 
						|
            });
 | 
						|
        });
 | 
						|
    </script>
 | 
						|
    <div class="actions">
 | 
						|
<?php
 | 
						|
 | 
						|
echo '<a href="'.api_get_path(WEB_CODE_PATH).'session/session_add.php">'.
 | 
						|
    Display::return_icon('new_session.png', get_lang('AddSession'), '', ICON_SIZE_MEDIUM).'</a>';
 | 
						|
if (api_is_platform_admin()) {
 | 
						|
    echo '<a href="'.api_get_path(WEB_CODE_PATH).'session/add_many_session_to_category.php">'.
 | 
						|
        Display::return_icon('session_to_category.png', get_lang('AddSessionsInCategories'), '', ICON_SIZE_MEDIUM).'</a>';
 | 
						|
    echo '<a href="'.api_get_path(WEB_CODE_PATH).'session/session_category_list.php">'.
 | 
						|
        Display::return_icon('folder.png', get_lang('ListSessionCategory'), '', ICON_SIZE_MEDIUM).'</a>';
 | 
						|
}
 | 
						|
 | 
						|
echo $actions;
 | 
						|
if (api_is_platform_admin()) {
 | 
						|
    echo '<div class="pull-right">';
 | 
						|
    // Create a search-box
 | 
						|
    $form = new FormValidator(
 | 
						|
        'search_simple',
 | 
						|
        'get',
 | 
						|
        '',
 | 
						|
        '',
 | 
						|
        [],
 | 
						|
        FormValidator::LAYOUT_INLINE
 | 
						|
    );
 | 
						|
    $form->addElement(
 | 
						|
        'text',
 | 
						|
        'keyword',
 | 
						|
        null,
 | 
						|
        [
 | 
						|
            'aria-label' => get_lang('Search'),
 | 
						|
        ]
 | 
						|
    );
 | 
						|
    $form->addButtonSearch(get_lang('Search'));
 | 
						|
    $form->display();
 | 
						|
    echo '</div>';
 | 
						|
 | 
						|
    echo '<div class="pull-right">';
 | 
						|
    echo $sessionFilter->returnForm();
 | 
						|
    echo '</div>';
 | 
						|
}
 | 
						|
echo '</div>';
 | 
						|
 | 
						|
echo SessionManager::getSessionListTabs($listType);
 | 
						|
echo '<div id="session-table" class="table-responsive">';
 | 
						|
echo Display::grid_html('sessions');
 | 
						|
echo '</div>';
 | 
						|
 | 
						|
Display::display_footer();
 | 
						|
 |