'; //jQuery $interbreadcrumb[] = array ('url' => $_SESSION['gradebook_dest'].'?selectcat=1', 'name' => get_lang('ToolGradebook')); $showeval = isset($_POST['showeval']) ? '1' : '0'; $showlink = isset($_POST['showlink']) ? '1' : '0'; if (($showlink == '0') && ($showeval == '0')) { $showlink = '1'; $showeval = '1'; } $cat = Category::load($_REQUEST['selectcat']); if (isset($_GET['userid'])) { $userid = Security::remove_XSS($_GET['userid']); } else { $userid = ''; } if ($showeval) { $alleval = $cat[0]->get_evaluations($userid, true); } else { $alleval = null; } if ($showlink) { $alllinks = $cat[0]->get_links($userid, true); } else { $alllinks = null; } if (isset($export_flatview_form) && (!$file_type == 'pdf')) { Display :: display_normal_message($export_flatview_form->toHtml(), false); } if (isset($_GET['selectcat'])) { $category_id = Security::remove_XSS($_GET['selectcat']); } else { $category_id = ''; } $simple_search_form = new UserForm(UserForm :: TYPE_SIMPLE_SEARCH, null, 'simple_search_form', null, api_get_self() . '?selectcat=' . $category_id); $values = $simple_search_form->exportValues(); $keyword = ''; if (isset($_GET['search']) && !empty($_GET['search'])) { $keyword = Security::remove_XSS($_GET['search']); } if ($simple_search_form->validate() && (empty($keyword))) { $keyword = $values['keyword']; } if (!empty($keyword)) { $users = find_students($keyword); } else { if (isset($alleval) && isset($alllinks)) { $users = get_all_users($alleval, $alllinks); } else { $users = null; } } if (isset ($_GET['exportpdf'])) { $interbreadcrumb[] = array ( 'url' => api_get_self().'?selectcat=' . Security::remove_XSS($_GET['selectcat']), 'name' => get_lang('FlatView') ); $export_pdf_form = new DataForm(DataForm :: TYPE_EXPORT_PDF, 'export_pdf_form', null, api_get_self().'?exportpdf=&offset='.$_GET['offset'].'&selectcat='.$_GET['selectcat'], '_blank'); if ($export_pdf_form->validate()) { // Beginning of PDF report creation $printable_data = get_printable_data($users, $alleval, $alllinks); $export = $export_pdf_form->exportValues(); // Reading report's CSS //$css_file = api_get_path(TO_SYS, WEB_CSS_PATH).api_get_setting('stylesheets').'/print.css'; $css_file = api_get_path(SYS_CODE_PATH).'gradebook/print.css'; $css = file_exists($css_file) ? @file_get_contents($css_file) : ''; // HTML report creation first $time = time(); $cat_name = trim($cat[0]->get_name()); $course_code = trim($cat[0]->get_course_code()); $report_name = $course_code; if (!empty($cat_name) && $report_name != $cat_name) { $report_name .= ' - '.$cat_name; } $organization = api_get_setting('Institution'); $creator = api_get_person_name($GLOBALS['_user']['firstName'], $GLOBALS['_user']['lastName']); $html = ''; if (!empty($organization)) { $html .= '

'.$organization.'

'; } $html .= '

'.get_lang('FlatView').'

'; $html .= '

'.$report_name.'

'; $html .= '

'.api_convert_and_format_date(date('Y-m-d', time()), 2).'

'; $html .= '

'.get_lang('By').': '.$creator.'

'; $columns = count($printable_data[0]); $has_data = is_array($printable_data[1]) && count($printable_data[1]) > 0; if (api_is_western_name_order()) { // Choosing the right person name order according to the current language. list($printable_data[0][0], $printable_data[0][1]) = array($printable_data[0][1], $printable_data[0][0]); if ($has_data) { foreach ($printable_data[1] as &$printable_data_row) { list($printable_data_row[0], $printable_data_row[1]) = array($printable_data_row[1], $printable_data_row[0]); } } } $table = new HTML_Table(array('class' => 'data_table')); $row = 0; $column = 0; foreach ($printable_data[0] as $printable_data_cell) { $table->setHeaderContents($row, $column, $printable_data_cell); $column++; } $row++; if ($has_data) { foreach ($printable_data[1] as &$printable_data_row) { $column = 0; foreach ($printable_data_row as &$printable_data_cell) { $table->setCellContents($row, $column, $printable_data_cell); $table->updateCellAttributes($row, $column, 'align="center"'); $column++; } $table->updateRowAttributes($row, $row % 2 ? 'class="row_even"' : 'class="row_odd"', true); $row++; } } else { $column = 0; $table->setCellContents($row, $column, get_lang('NoResults')); $table->updateCellAttributes($row, $column, 'colspan="'.$columns.'" align="center" class="row_odd"'); } $html .= $table->toHtml(); $html .= ''; // Memory release unset($printable_data); unset($table); // Conversion of the created HTML report to a PDF report $html = api_utf8_encode($html); $creator_pdf = api_utf8_encode($creator); $title_pdf = api_utf8_encode($report_name); $subject_pdf = api_utf8_encode(get_lang('FlatView')); $keywods_pdf = api_utf8_encode($course_code); $page_format = $export['orientation'] == 'landscape' ? 'A4-L' : 'A4'; $pdf = new mPDF('UTF-8', $page_format, '', '', 32, 25, 27, 25, 16, 13, $export['orientation']); $pdf->directionality = api_get_text_direction(); $pdf->useOnlyCoreFonts = true; $pdf->SetFooter('{PAGENO}'); $pdf->SetAuthor($creator_pdf); $pdf->SetTitle($title_pdf); $pdf->SetSubject($subject_pdf); $pdf->SetKeywords($keywods_pdf); if (!empty($css)) { $pdf->WriteHTML($css, 1); $pdf->WriteHTML($html, 2); } else { $pdf->WriteHTML($html); } // Sending the created PDF report to the client $file_name = date('YmdHi_', $time); if (!empty($course_code)) { $file_name .= $course_code.'_'; } $file_name .= get_lang('FlatView').'.pdf'; $file_name = replace_dangerous_char($file_name); $pdf->Output($file_name, 'D'); /* // This is the old pdf-exporting routine that uses ezpdf library. // $format = $export['orientation']; //format is 'portrait' or 'landscape' $pdf =& new Cezpdf('a4',$format); //format is 'portrait' or 'landscape' $clear_printable_data=array(); $clear_send_printable_data=array(); for ($i=0;$iget_name()); exit; } if (!empty($_POST['export_report']) && $_POST['export_report'] == 'export_report') { if (api_is_platform_admin() || api_is_course_admin() || api_is_course_coach()) { $user_id = null; if (empty($_SESSION['export_user_fields'])) { $_SESSION['export_user_fields'] = false; } if (!api_is_allowed_to_edit(false, false) and !api_is_course_tutor()) { $user_id = api_get_user_id(); } require_once 'gradebook_result.class.php'; $printable_data = get_printable_data($users, $alleval, $alllinks); //exit; switch($_POST['export_format']) { case 'xls': $export = new GradeBookResult(); $export->exportCompleteReportXLS($printable_data); exit; break; case 'csv': default: $export = new GradeBookResult(); $export->exportCompleteReportCSV($printable_data); exit; break; } } else { api_not_allowed(true); } } $addparams = array ('selectcat' => $cat[0]->get_id()); if (isset($_GET['search'])) { $addparams['search'] = $keyword; } $offset = isset($_GET['offset']) ? $_GET['offset'] : '0'; $flatviewtable = new FlatViewTable($cat[0], $users, $alleval, $alllinks, true, $offset, $addparams); $this_section = SECTION_COURSES; if (isset($_GET['exportpdf'])) { echo '
'; $export_pdf_form->display(); echo '
'; } else { Display :: display_header(get_lang('FlatView')); } if (isset($_GET['isStudentView']) && $_GET['isStudentView'] == 'false') { DisplayGradebook :: display_header_reduce_flatview($cat[0], $showeval, $showlink, $simple_search_form); $flatviewtable->display(); } elseif (isset($_GET['selectcat']) && ($_SESSION['studentview'] == 'teacherview')) { DisplayGradebook :: display_header_reduce_flatview($cat[0], $showeval, $showlink, $simple_search_form); /*echo '
'; echo Display::display_icon('loader.gif'); echo '
';*/ // main graph //@todo load images with jquery echo '
'; $image_file = $flatviewtable->display_graph(); $my_info_path_img = array(); $my_info_path_img = explode('/', $image_file); if (strlen($my_info_path_img[5]) == 32) { echo ''; } $flatviewtable->display(); $flatviewtable->display_graph_by_resource(); echo '
'; } Display :: display_footer();