📄 display.lib.php
字号:
<?php/*============================================================================== Dokeos - elearning and course management software Copyright (c) 2004-2008 Dokeos S.A. Copyright (c) Roan Embrechts, Vrije Universiteit Brussel Copyright (c) Wolfgang Schneider Copyright (c) Bert Vanderkimpen, Ghent University Copyright (c) Bart Mollet, Hogeschool Gent Copyright (c) Rene Haentjens, Ghent University Copyright (c) Yannick Warnier, Dokeos S.A. Copyright (c) Sandra Matthys, Hogeschool Gent Copyright (c) Denes Nagy, Dokeos S.A. For a full list of contributors, see "credits.txt". The full license can be read in "license.txt". This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the GNU General Public License for more details. Contact address: Dokeos, 44 rue des palais, B-1030 Brussels, Belgium Mail: info@dokeos.com==============================================================================*//**==============================================================================* This is a display library for Dokeos.** Include/require it in your code to use its functionality.* There are also several display functions in the main api library.** All functions static functions inside a class called Display,* so you use them like this: e.g.* Display::display_normal_message($message)** @package dokeos.library==============================================================================*//*============================================================================== CONSTANTS==============================================================================*//*============================================================================== LIBRARIES==============================================================================*///no other libraries needed at the moment/*============================================================================== FUNCTIONS==============================================================================*///all functions are stored inside the Display class/*============================================================================== CLASS Display functions inside ---------------- Display::display_localised_html_file($full_file_name) Display::display_table_header() Display::display_complex_table_header($properties, $column_header) Display::display_table_row($bgcolor, $table_row, $is_alternating=true) Display::display_table_footer() Display::display_normal_message($message) Display::display_error_message($message) Display::encrypted_mailto_link($email, $clickable_text, $style_class='') Display::get_platform_home_link_html($name = '')==============================================================================*//*** Display class* contains several functions dealing with the display of* table data, messages, help topics, ...** @version 1.0.4* @package dokeos.library*/require_once 'sortabletable.class.php';class Display { /** * Displays the tool introduction of a tool. * * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University * @param string $tool These are the constants that are used for indicating the tools * @return html code for adding an introduction */ function display_introduction_section($tool) { $is_allowed_to_edit = api_is_allowed_to_edit(); $moduleId = $tool; if (api_get_setting('enable_tool_introduction') == 'true' || $tool==TOOL_COURSE_HOMEPAGE) { include (api_get_path(INCLUDE_PATH)."introductionSection.inc.php"); } } /* * Displays a localised html file * * tries to show the file "$full_file_name"."_".$language_interface.".html" * and if this does not exist, shows the file "$full_file_name".".html" * * warning this function defines a global * * @param $full_file_name, the (path) name of the file, without .html */ function display_localised_html_file($full_file_name) { global $language_interface; $localised_file_name = $full_file_name."_".$language_interface.".html"; $default_file_name = $full_file_name.".html"; if (file_exists($localised_file_name)) { include ($localised_file_name); } else { include ($default_file_name); //default } } /** * Display simple html header of table. */ function display_table_header() { $bgcolor = "bgcolor='white'"; echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"4\" width=\"85%\"><tbody>"; return $bgcolor; } /** * Display html header of table with several options. * * @param $properties, array with elements, all of which have defaults * "width" - the table width, e.g. "100%", default is 85% * "class" - the class to use for the table, e.g. "class=\"data_table\"" * "cellpadding" - the extra border in each cell, e.g. "8",default is 4 * "cellspacing" - the extra space between cells, default = 0 * * @param column_header, array with the header elements. * @author Roan Embrechts * @version 1.01 */ function display_complex_table_header($properties, $column_header) { $width = $properties["width"]; if (!isset ($width)) $width = "85%"; $class = $properties["class"]; if (!isset ($class)) $class = "class=\"data_table\""; $cellpadding = $properties["cellpadding"]; if (!isset ($cellpadding)) $cellpadding = "4"; $cellspacing = $properties["cellspacing"]; if (!isset ($cellspacing)) $cellspacing = "0"; //... add more properties as you see fit //api_display_debug_info("Dokeos light grey is " . DOKEOSLIGHTGREY); $bgcolor = "bgcolor='".DOKEOSLIGHTGREY."'"; echo "<table $class border=\"0\" cellspacing=\"$cellspacing\" cellpadding=\"$cellpadding\" width=\"$width\">\n"; echo "<thead><tr $bgcolor>"; foreach ($column_header as $table_element) { echo "<th>".$table_element."</th>"; } echo "</tr></thead>\n"; echo "<tbody>\n"; $bgcolor = "bgcolor='".HTML_WHITE."'"; return $bgcolor; } /** * Displays a table row. * * @param $bgcolor the background colour for the table * @param $table_row an array with the row elements * @param $is_alternating true: the row colours alternate, false otherwise */ function display_table_row($bgcolor, $table_row, $is_alternating = true) { echo "<tr $bgcolor>"; foreach ($table_row as $table_element) { echo "<td>".$table_element."</td>"; } echo "</tr>\n"; if ($is_alternating) { if ($bgcolor == "bgcolor='".HTML_WHITE."'") { $bgcolor = "bgcolor='".DOKEOSLIGHTGREY."'"; } else { if ($bgcolor == "bgcolor='".DOKEOSLIGHTGREY."'") { $bgcolor = "bgcolor='".HTML_WHITE."'"; } } } return $bgcolor; } /** * Displays a table row. * This function has more options and is easier to extend than display_table_row() * * @param $properties, array with properties: * ["bgcolor"] - the background colour for the table * ["is_alternating"] - true: the row colours alternate, false otherwise * ["align_row"] - an array with, per cell, left|center|right * @todo add valign property */ function display_complex_table_row($properties, $table_row) { $bgcolor = $properties["bgcolor"]; $is_alternating = $properties["is_alternating"]; $align_row = $properties["align_row"]; echo "<tr $bgcolor>"; $number_cells = count($table_row); for ($i = 0; $i < $number_cells; $i ++) { $cell_data = $table_row[$i]; $cell_align = $align_row[$i]; echo "<td align=\"$cell_align\">".$cell_data."</td>"; } echo "</tr>\n"; if ($is_alternating) { if ($bgcolor == "bgcolor='".HTML_WHITE."'") $bgcolor = "bgcolor='".DOKEOSLIGHTGREY."'"; else if ($bgcolor == "bgcolor='".DOKEOSLIGHTGREY."'") $bgcolor = "bgcolor='".HTML_WHITE."'"; } return $bgcolor; } /** * display html footer of table */ function display_table_footer() { echo "</tbody></table>"; } /** * Display a table * @param array $header Titles for the table header * each item in this array can contain 3 values * - 1st element: the column title * - 2nd element: true or false (column sortable?) * - 3th element: additional attributes for * th-tag (eg for column-width) * - 4the element: additional attributes for the td-tags * @param array $content 2D-array with the tables content * @param array $sorting_options Keys are: * 'column' = The column to use as sort-key * 'direction' = SORT_ASC or SORT_DESC * @param array $paging_options Keys are: * 'per_page_default' = items per page when switching from * full- list to per-page-view * 'per_page' = number of items to show per page * 'page_nr' = The page to display * @param array $query_vars Additional variables to add in the query-string * @author bart.mollet@hogent.be */ function display_sortable_table($header, $content, $sorting_options = array (), $paging_options = array (), $query_vars = null, $form_actions=array()) { global $origin; $column = isset ($sorting_options['column']) ? $sorting_options['column'] : 0; $default_items_per_page = isset ($paging_options['per_page']) ? $paging_options['per_page'] : 20; $table = new SortableTableFromArray($content, $column, $default_items_per_page); if (is_array($query_vars)) { $table->set_additional_parameters($query_vars); } foreach ($header as $index => $header_item) { $table->set_header($index, $header_item[0], $header_item[1], $header_item[2], $header_item[3]); } $table->set_form_actions($form_actions); $table->display(); } /** * Display a table with a special configuration * @param array $header Titles for the table header * each item in this array can contain 3 values * - 1st element: the column title * - 2nd element: true or false (column sortable?) * - 3th element: additional attributes for * th-tag (eg for column-width) * - 4the element: additional attributes for the td-tags * @param array $content 2D-array with the tables content * @param array $sorting_options Keys are: * 'column' = The column to use as sort-key * 'direction' = SORT_ASC or SORT_DESC * @param array $paging_options Keys are: * 'per_page_default' = items per page when switching from * full- list to per-page-view * 'per_page' = number of items to show per page * 'page_nr' = The page to display * @param array $query_vars Additional variables to add in the query-string * @param array $column_show Array of binaries 1= show columns 0. hide a column * @param array $column_order An array of integers that let us decide how the columns are going to be sort. * i.e: $column_order=array('1''4','3','4'); The 2nd column will be order like the 4th column * @param array $form_actions Set optional forms actions * * @author Julio Montoya */ function display_sortable_config_table($header, $content, $sorting_options = array (), $paging_options = array (), $query_vars = null, $column_show=array(),$column_order=array(),$form_actions=array()) { global $origin; $column = isset ($sorting_options['column']) ? $sorting_options['column'] : 0; $default_items_per_page = isset ($paging_options['per_page']) ? $paging_options['per_page'] : 20; $table = new SortableTableFromArrayConfig($content, $column, $default_items_per_page,'tablename',$column_show,$column_order); if (is_array($query_vars)) { $table->set_additional_parameters($query_vars); } // show or hide the columns header
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -