123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848 |
- <?php
- /* For licensing terms, see /license.txt */
- use ChamiloSession as Session;
- /**
- * Class GlossaryManager
- * This library provides functions for the glossary tool.
- * Include/require it in your code to use its functionality.
- *
- * @author Julio Montoya
- * @author Christian Fasanando
- * @author Patrick Cool <patrick.cool@ugent.be>, Ghent University, Belgium januari 2009, dokeos 1.8.6
- *
- * @package chamilo.library
- */
- class GlossaryManager
- {
- /**
- * Get all glossary terms.
- *
- * @author Isaac Flores <isaac.flores@dokeos.com>
- *
- * @return array Contain glossary terms
- */
- public static function get_glossary_terms()
- {
- $glossary_data = [];
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $session_id = api_get_session_id();
- $sql_filter = api_get_session_condition($session_id);
- $course_id = api_get_course_int_id();
- $sql = "SELECT glossary_id as id, name, description
- FROM $table
- WHERE c_id = $course_id $sql_filter";
- $rs = Database::query($sql);
- while ($row = Database::fetch_array($rs)) {
- $glossary_data[] = $row;
- }
- return $glossary_data;
- }
- /**
- * Get glossary description by glossary id.
- *
- * @author Isaac Flores <florespaz@bidsoftperu.com>
- *
- * @param int $glossary_id
- *
- * @return string The glossary description
- */
- public static function get_glossary_term_by_glossary_id($glossary_id)
- {
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $glossary_id = (int) $glossary_id;
- $sql = "SELECT description
- FROM $table
- WHERE c_id = $course_id AND glossary_id =".$glossary_id;
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- $row = Database::fetch_array($rs);
- return $row['description'];
- }
- return '';
- }
- /**
- * Get glossary term by glossary id.
- *
- * @author Isaac Flores <florespaz_isaac@hotmail.com>
- *
- * @param string $glossary_name The glossary term name
- *
- * @return array The glossary info
- */
- public static function get_glossary_term_by_glossary_name($glossary_name)
- {
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $session_id = api_get_session_id();
- $course_id = api_get_course_int_id();
- $sql_filter = api_get_session_condition($session_id);
- $sql = 'SELECT * FROM '.$table.'
- WHERE
- c_id = '.$course_id.' AND
- name LIKE trim("'.Database::escape_string($glossary_name).'")'.$sql_filter;
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- $row = Database::fetch_array($rs, 'ASSOC');
- return $row;
- }
- return [];
- }
- /**
- * This functions stores the glossary in the database.
- *
- * @param array $values Array of title + description (name => $title, description => $comment)
- *
- * @return mixed Term id on success, false on failure
- */
- public static function save_glossary($values, $showMessage = true)
- {
- if (!is_array($values) || !isset($values['name'])) {
- return false;
- }
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- // get the maximum display order of all the glossary items
- $max_glossary_item = self::get_max_glossary_item();
- // session_id
- $session_id = api_get_session_id();
- // check if the glossary term already exists
- if (self::glossary_exists($values['name'])) {
- // display the feedback message
- if ($showMessage) {
- Display::addFlash(
- Display::return_message(get_lang('GlossaryTermAlreadyExistsYouShouldEditIt'), 'error')
- );
- }
- return false;
- } else {
- $params = [
- 'glossary_id' => 0,
- 'c_id' => api_get_course_int_id(),
- 'name' => $values['name'],
- 'description' => $values['description'],
- 'display_order' => $max_glossary_item + 1,
- 'session_id' => $session_id,
- ];
- $id = Database::insert($table, $params);
- if ($id) {
- $sql = "UPDATE $table SET glossary_id = $id WHERE iid = $id";
- Database::query($sql);
- //insert into item_property
- api_item_property_update(
- api_get_course_info(),
- TOOL_GLOSSARY,
- $id,
- 'GlossaryAdded',
- api_get_user_id()
- );
- }
- // display the feedback message
- if ($showMessage) {
- Display::addFlash(
- Display::return_message(get_lang('TermAdded'))
- );
- }
- return $id;
- }
- }
- /**
- * update the information of a glossary term in the database.
- *
- * @param array $values an array containing all the form elements
- *
- * @return bool True on success, false on failure
- */
- public static function update_glossary($values, $showMessage = true)
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- // check if the glossary term already exists
- if (self::glossary_exists($values['name'], $values['glossary_id'])) {
- // display the feedback message
- if ($showMessage) {
- Display::addFlash(
- Display::return_message(get_lang('GlossaryTermAlreadyExistsYouShouldEditIt'), 'error')
- );
- }
- return false;
- } else {
- $sql = "UPDATE $table SET
- name = '".Database::escape_string($values['name'])."',
- description = '".Database::escape_string($values['description'])."'
- WHERE
- c_id = $course_id AND
- glossary_id = ".intval($values['glossary_id']);
- $result = Database::query($sql);
- if ($result === false) {
- return false;
- }
- //update glossary into item_property
- api_item_property_update(
- api_get_course_info(),
- TOOL_GLOSSARY,
- intval($values['glossary_id']),
- 'GlossaryUpdated',
- api_get_user_id()
- );
- if ($showMessage) {
- // display the feedback message
- Display::addFlash(
- Display::return_message(get_lang('TermUpdated'))
- );
- }
- }
- return true;
- }
- /**
- * Get the maximum display order of the glossary item.
- *
- * @return int Maximum glossary display order
- */
- public static function get_max_glossary_item()
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $get_max = "SELECT MAX(display_order) FROM $table
- WHERE c_id = $course_id ";
- $res_max = Database::query($get_max);
- if (Database::num_rows($res_max) == 0) {
- return 0;
- }
- $row = Database::fetch_array($res_max);
- if (!empty($row[0])) {
- return $row[0];
- }
- return 0;
- }
- /**
- * check if the glossary term exists or not.
- *
- * @param string $term Term to look for
- * @param int $not_id ID to counter-check if the term exists with this ID as well (optional)
- *
- * @return bool True if term exists
- */
- public static function glossary_exists($term, $not_id = '')
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $sql = "SELECT name FROM $table
- WHERE
- c_id = $course_id AND
- name = '".Database::escape_string($term)."'";
- if ($not_id != '') {
- $sql .= " AND glossary_id <> '".intval($not_id)."'";
- }
- $result = Database::query($sql);
- $count = Database::num_rows($result);
- if ($count > 0) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Get one specific glossary term data.
- *
- * @param int $glossary_id ID of the glossary term
- *
- * @return mixed Array(glossary_id,name,description,glossary_display_order) or false on error
- */
- public static function get_glossary_information($glossary_id)
- {
- // Database table definition
- $t_glossary = Database::get_course_table(TABLE_GLOSSARY);
- $t_item_propery = Database::get_course_table(TABLE_ITEM_PROPERTY);
- if (empty($glossary_id)) {
- return false;
- }
- $sql = "SELECT
- g.glossary_id as glossary_id,
- g.name as name,
- g.description as description,
- g.display_order as glossary_display_order,
- ip.insert_date as insert_date,
- ip.lastedit_date as update_date,
- g.session_id
- FROM $t_glossary g
- INNER JOIN $t_item_propery ip
- ON (g.glossary_id = ip.ref AND g.c_id = ip.c_id)
- WHERE
- tool = '".TOOL_GLOSSARY."' AND
- g.glossary_id = '".intval($glossary_id)."' AND
- g.c_id = ".api_get_course_int_id()." AND
- ip.c_id = ".api_get_course_int_id();
- $result = Database::query($sql);
- if ($result === false || Database::num_rows($result) != 1) {
- return false;
- }
- return Database::fetch_array($result);
- }
- /**
- * Delete a glossary term (and re-order all the others).
- *
- * @param int $glossary_id
- * @param bool $showMessage
- *
- * @return bool True on success, false on failure
- */
- public static function delete_glossary($glossary_id, $showMessage = true)
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $glossaryInfo = self::get_glossary_information($glossary_id);
- if (empty($glossaryInfo)) {
- return false;
- }
- $glossary_id = (int) $glossary_id;
- $sql = "DELETE FROM $table
- WHERE
- c_id = $course_id AND
- glossary_id='".$glossary_id."'";
- $result = Database::query($sql);
- if ($result === false || Database::affected_rows($result) < 1) {
- return false;
- }
- // update item_property (delete)
- api_item_property_update(
- api_get_course_info(),
- TOOL_GLOSSARY,
- $glossary_id,
- 'delete',
- api_get_user_id()
- );
- // reorder the remaining terms
- self::reorder_glossary();
- if ($showMessage) {
- Display::addFlash(
- Display::return_message(get_lang('TermDeleted').': '.$glossaryInfo['name'])
- );
- }
- return true;
- }
- /**
- * @return string
- */
- public static function getGlossaryView()
- {
- $view = Session::read('glossary_view');
- if (empty($view)) {
- $defaultView = api_get_configuration_value('default_glossary_view');
- if (empty($defaultView)) {
- $defaultView = 'table';
- }
- return $defaultView;
- } else {
- return $view;
- }
- }
- /**
- * This is the main function that displays the list or the table with all
- * the glossary terms
- * Defaults to 'table' and prefers glossary_view from the session by default.
- *
- * @return string
- */
- public static function display_glossary()
- {
- // This function should always be called with the corresponding
- // parameter for view type. Meanwhile, use this cheap trick.
- $view = self::getGlossaryView();
- // action links
- $actionsLeft = '';
- if (api_is_allowed_to_edit(null, true)) {
- $actionsLeft .= '<a href="index.php?'.api_get_cidreq().'&action=addglossary&msg=add?'.api_get_cidreq().'">'.
- Display::return_icon('new_glossary_term.png', get_lang('TermAddNew'), '', ICON_SIZE_MEDIUM).'</a>';
- }
- if (api_is_allowed_to_edit(null, true)) {
- $actionsLeft .= '<a href="index.php?'.api_get_cidreq().'&action=import">'.
- Display::return_icon('import.png', get_lang('ImportGlossary'), '', ICON_SIZE_MEDIUM).'</a>';
- }
- if (!api_is_anonymous()) {
- $actionsLeft .= '<a id="export_opener" href="'.api_get_self().'?'.api_get_cidreq().'&action=export">'.
- Display::return_icon('save.png', get_lang('Export'), '', ICON_SIZE_MEDIUM).'</a>';
- }
- if (($view == 'table') || (!isset($view))) {
- $actionsLeft .= '<a href="index.php?'.api_get_cidreq().'&action=changeview&view=list">'.
- Display::return_icon('view_detailed.png', get_lang('ListView'), '', ICON_SIZE_MEDIUM).'</a>';
- } else {
- $actionsLeft .= '<a href="index.php?'.api_get_cidreq().'&action=changeview&view=table">'.
- Display::return_icon('view_text.png', get_lang('TableView'), '', ICON_SIZE_MEDIUM).'</a>';
- }
- if (api_is_allowed_to_edit(true, true, true)) {
- $actionsLeft .= Display::url(
- Display::return_icon('export_to_documents.png', get_lang('ExportToDocArea'), [], ICON_SIZE_MEDIUM),
- api_get_self().'?'.api_get_cidreq().'&'.http_build_query(['action' => 'export_documents'])
- );
- }
- /* BUILD SEARCH FORM */
- $form = new FormValidator(
- 'search',
- 'get',
- api_get_self().'?'.api_get_cidreq(),
- '',
- [],
- FormValidator::LAYOUT_INLINE
- );
- $form->addText('keyword', '', false, ['class' => 'col-md-2']);
- $form->addElement('hidden', 'cidReq', api_get_course_id());
- $form->addElement('hidden', 'id_session', api_get_session_id());
- $form->addButtonSearch(get_lang('Search'));
- $actionsRight = $form->returnForm();
- $toolbar = Display::toolbarAction(
- 'toolbar-document',
- [$actionsLeft, $actionsRight]
- );
- $content = $toolbar;
- if (!$view || $view === 'table') {
- $table = new SortableTable(
- 'glossary',
- ['GlossaryManager', 'get_number_glossary_terms'],
- ['GlossaryManager', 'get_glossary_data'],
- 0
- );
- //$table->set_header(0, '', false);
- $table->set_header(0, get_lang('TermName'), true);
- $table->set_header(1, get_lang('TermDefinition'), true);
- if (api_is_allowed_to_edit(null, true)) {
- $table->set_header(2, get_lang('Actions'), false, 'width=90px', ['class' => 'td_actions']);
- $table->set_column_filter(2, ['GlossaryManager', 'actions_filter']);
- }
- $content .= $table->return_table();
- }
- if ($view === 'list') {
- $content .= self::displayGlossaryList();
- }
- return $content;
- }
- /**
- * Display the glossary terms in a list.
- *
- * @return bool true
- */
- public static function displayGlossaryList()
- {
- $glossaryList = self::get_glossary_data(0, 1000, 0, 'ASC');
- $content = '';
- foreach ($glossaryList as $key => $glossary_item) {
- $actions = '';
- if (api_is_allowed_to_edit(null, true)) {
- $actions = '<div class="pull-right">'.self::actions_filter($glossary_item[2], '', $glossary_item).'</div>';
- }
- $content .= Display::panel($glossary_item[1], $glossary_item[0].' '.$actions);
- }
- return $content;
- }
- /**
- * Get the number of glossary terms in the course (or course+session).
- *
- * @param int Session ID filter (optional)
- *
- * @return int Count of glossary terms
- */
- public static function get_number_glossary_terms($session_id = 0)
- {
- // Database table definition
- $t_glossary = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $session_id = intval($session_id);
- $sql_filter = api_get_session_condition($session_id, true, true);
- $keyword = isset($_GET['keyword']) ? Database::escape_string($_GET['keyword']) : '';
- $keywordCondition = '';
- if (!empty($keyword)) {
- $keywordCondition = "AND (name LIKE '%$keyword%' OR description LIKE '%$keyword%')";
- }
- $sql = "SELECT count(glossary_id) as total
- FROM $t_glossary
- WHERE c_id = $course_id $sql_filter
- $keywordCondition ";
- $res = Database::query($sql);
- if ($res === false) {
- return 0;
- }
- $obj = Database::fetch_object($res);
- return $obj->total;
- }
- /**
- * Get all the data of a glossary.
- *
- * @param int $from From which item
- * @param int $number_of_items Number of items to collect
- * @param string $column Name of column on which to order
- * @param string $direction Whether to sort in ascending (ASC) or descending (DESC)
- *
- * @return array
- */
- public static function get_glossary_data(
- $from,
- $number_of_items,
- $column,
- $direction
- ) {
- $_user = api_get_user_info();
- $view = self::getGlossaryView();
- // Database table definition
- $t_glossary = Database::get_course_table(TABLE_GLOSSARY);
- $t_item_propery = Database::get_course_table(TABLE_ITEM_PROPERTY);
- if (api_is_allowed_to_edit(null, true)) {
- $col2 = " glossary.glossary_id as col2, ";
- } else {
- $col2 = ' ';
- }
- //condition for the session
- $session_id = api_get_session_id();
- $condition_session = api_get_session_condition(
- $session_id,
- true,
- true,
- 'glossary.session_id'
- );
- $column = intval($column);
- if (!in_array($direction, ['DESC', 'ASC'])) {
- $direction = 'ASC';
- }
- $from = intval($from);
- $number_of_items = intval($number_of_items);
- $keyword = isset($_GET['keyword']) ? Database::escape_string($_GET['keyword']) : '';
- $keywordCondition = '';
- if (!empty($keyword)) {
- $keywordCondition = "AND (glossary.name LIKE '%$keyword%' OR glossary.description LIKE '%$keyword%')";
- }
- $sql = "SELECT
- glossary.name as col0,
- glossary.description as col1,
- $col2
- glossary.session_id
- FROM $t_glossary glossary
- INNER JOIN $t_item_propery ip
- ON (glossary.glossary_id = ip.ref AND glossary.c_id = ip.c_id)
- WHERE
- tool = '".TOOL_GLOSSARY."'
- $condition_session AND
- glossary.c_id = ".api_get_course_int_id()." AND
- ip.c_id = ".api_get_course_int_id()."
- $keywordCondition
- ORDER BY col$column $direction
- LIMIT $from,$number_of_items";
- $res = Database::query($sql);
- $return = [];
- $array = [];
- while ($data = Database::fetch_array($res)) {
- // Validation when belongs to a session
- $session_img = api_get_session_image($data['session_id'], $_user['status']);
- $array[0] = $data[0].$session_img;
- if (!$view || $view === 'table') {
- $array[1] = str_replace(['<p>', '</p>'], ['', '<br />'], $data[1]);
- } else {
- $array[1] = $data[1];
- }
- if (isset($_GET['action']) && $_GET['action'] == 'export') {
- $array[1] = api_html_entity_decode($data[1]);
- }
- if (api_is_allowed_to_edit(null, true)) {
- $array[2] = $data[2];
- }
- $return[] = $array;
- }
- return $return;
- }
- /**
- * Update action icons column.
- *
- * @param int $glossary_id
- * @param array $url_params Parameters to use to affect links
- * @param array $row The line of results from a query on the glossary table
- *
- * @return string HTML string for the action icons columns
- */
- public static function actions_filter($glossary_id, $url_params, $row)
- {
- $glossary_id = $row[2];
- $return = '<a href="'.api_get_self().'?action=edit_glossary&glossary_id='.$glossary_id.'&'.api_get_cidreq().'&msg=edit">'.
- Display::return_icon('edit.png', get_lang('Edit'), '', 22).'</a>';
- $glossary_data = self::get_glossary_information($glossary_id);
- $glossary_term = $glossary_data['name'];
- if (api_is_allowed_to_edit(null, true)) {
- if ($glossary_data['session_id'] == api_get_session_id()) {
- $return .= '<a href="'.api_get_self().'?action=delete_glossary&glossary_id='.$glossary_id.'&'.api_get_cidreq().'" onclick="return confirmation(\''.$glossary_term.'\');">'.
- Display::return_icon('delete.png', get_lang('Delete'), '', 22).'</a>';
- } else {
- $return = get_lang('EditionNotAvailableFromSession');
- }
- }
- return $return;
- }
- /**
- * a little bit of javascript to display a prettier warning when deleting a term.
- *
- * @return string HTML string including JavaScript
- */
- public static function javascript_glossary()
- {
- return "<script>
- function confirmation (name) {
- if (confirm(\" ".get_lang("TermConfirmDelete")." \"+ name + \" ?\")) {
- return true;
- } else {
- return false;
- }
- }
- </script>";
- }
- /**
- * Re-order glossary.
- */
- public static function reorder_glossary()
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- $course_id = api_get_course_int_id();
- $sql = "SELECT * FROM $table
- WHERE c_id = $course_id
- ORDER by display_order ASC";
- $res = Database::query($sql);
- $i = 1;
- while ($data = Database::fetch_array($res)) {
- $sql = "UPDATE $table SET display_order = $i
- WHERE c_id = $course_id AND glossary_id = '".intval($data['glossary_id'])."'";
- Database::query($sql);
- $i++;
- }
- }
- /**
- * Move a glossary term.
- *
- * @param string $direction
- * @param string $glossary_id
- */
- public static function move_glossary($direction, $glossary_id)
- {
- // Database table definition
- $table = Database::get_course_table(TABLE_GLOSSARY);
- // sort direction
- if ($direction === 'up') {
- $sortorder = 'DESC';
- } else {
- $sortorder = 'ASC';
- }
- $course_id = api_get_course_int_id();
- $sql = "SELECT * FROM $table
- WHERE c_id = $course_id
- ORDER BY display_order $sortorder";
- $res = Database::query($sql);
- $found = false;
- while ($row = Database::fetch_array($res)) {
- if ($found && empty($next_id)) {
- $next_id = $row['glossary_id'];
- $next_display_order = $row['display_order'];
- }
- if ($row['glossary_id'] == $glossary_id) {
- $current_id = $glossary_id;
- $current_display_order = $row['display_order'];
- $found = true;
- }
- }
- $sql1 = "UPDATE $table SET display_order = '".Database::escape_string($next_display_order)."'
- WHERE c_id = $course_id AND glossary_id = '".Database::escape_string($current_id)."'";
- $sql2 = "UPDATE $table SET display_order = '".Database::escape_string($current_display_order)."'
- WHERE c_id = $course_id AND glossary_id = '".Database::escape_string($next_id)."'";
- Database::query($sql1);
- Database::query($sql2);
- Display::addFlash(Display::return_message(get_lang('TermMoved')));
- }
- /**
- * Export to pdf.
- */
- public static function export_to_pdf()
- {
- $data = self::get_glossary_data(
- 0,
- self::get_number_glossary_terms(api_get_session_id()),
- 0,
- 'ASC'
- );
- $template = new Template('', false, false, false, true, false, false);
- $layout = $template->get_template('glossary/export_pdf.tpl');
- $template->assign('items', $data);
- $html = $template->fetch($layout);
- $courseCode = api_get_course_id();
- $pdf = new PDF();
- $pdf->content_to_pdf($html, '', get_lang('Glossary').'_'.$courseCode, $courseCode);
- }
- /**
- * Generate a PDF with all glossary terms and move file to documents.
- *
- * @return bool false if there's nothing in the glossary
- */
- public static function movePdfToDocuments()
- {
- $sessionId = api_get_session_id();
- $courseId = api_get_course_int_id();
- $data = self::get_glossary_data(
- 0,
- self::get_number_glossary_terms($sessionId),
- 0,
- 'ASC'
- );
- if (!empty($data)) {
- $template = new Template('', false, false, false, true, false, false);
- $layout = $template->get_template('glossary/export_pdf.tpl');
- $template->assign('items', $data);
- $fileName = get_lang('Glossary').'-'.api_get_local_time();
- $signatures = ['Drh', 'Teacher', 'Date'];
- $pdf = new PDF(
- 'A4-P',
- 'P',
- [
- 'filename' => $fileName,
- 'pdf_title' => $fileName,
- 'add_signatures' => $signatures,
- ]
- );
- $pdf->exportFromHtmlToDocumentsArea(
- $template->fetch($layout),
- $fileName,
- $courseId
- );
- return true;
- } else {
- Display::addFlash(Display::return_message(get_lang('NothingToAdd')));
- }
- return false;
- }
- /**
- * @param string $format
- */
- public static function exportToFormat($format)
- {
- if ($format == 'pdf') {
- self::export_to_pdf();
- return;
- }
- $data = self::get_glossary_data(
- 0,
- self::get_number_glossary_terms(api_get_session_id()),
- 0,
- 'ASC'
- );
- usort($data, 'sorter');
- $list = [];
- $list[] = ['term', 'definition'];
- $allowStrip = api_get_configuration_value('allow_remove_tags_in_glossary_export');
- foreach ($data as $line) {
- $definition = $line[1];
- if ($allowStrip) {
- // htmlspecialchars_decode replace ' to '
- // strip_tags remove HTML tags
- $definition = htmlspecialchars_decode(strip_tags($definition), ENT_QUOTES);
- }
- $list[] = [$line[0], $definition];
- }
- $filename = 'glossary_course_'.api_get_course_id();
- switch ($format) {
- case 'csv':
- Export::arrayToCsv($list, $filename);
- break;
- case 'xls':
- Export::arrayToXls($list, $filename);
- break;
- }
- }
- }
|