123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626 |
- <?php
- /* See license terms in /license.txt */
- /**
- * @package chamilo.library
- */
- /**
- * Code
- */
- class PDF
- {
- public $pdf;
- public $custom_header = '';
- public $custom_footer = '';
- public $params = array();
- /**
- * Creates the mPDF object
- * @param string format A4 A4-L see http://mpdf1.com/manual/index.php?tid=184&searchstring=format
- * @param string orientation "P" = Portrait "L" = Landscape
- */
- public function __construct($page_format = 'A4', $orientation = 'P', $params = array())
- {
- /* More info @ http://mpdf1.com/manual/index.php?tid=184&searchstring=mPDF
- * mPDF ([ string $mode [, mixed $format [, float $default_font_size [, string $default_font [, float $margin_left , float $margin_right , float $margin_top , float $margin_bottom , float $margin_header , float $margin_footer [, string $orientation ]]]]]])
- */
- if (!in_array($orientation, array('P', 'L'))) {
- $orientation = 'P';
- }
- //$this->pdf = $pdf = new mPDF('UTF-8', $page_format, '', '', 30, 20, 27, 25, 16, 13, $orientation);
- //left, right, top, bottom, margin_header, margin footer
- $params['left'] = isset($params['left']) ? $params['left'] : 15;
- $params['right'] = isset($params['right']) ? $params['right'] : 15;
- $params['top'] = isset($params['top']) ? $params['top'] : 20;
- $params['bottom'] = isset($params['bottom']) ? $params['bottom'] : 15;
- $this->params['filename'] = isset($params['filename']) ? $params['filename'] : api_get_local_time();
- $this->params['pdf_title'] = isset($params['pdf_title']) ? $params['pdf_title'] : get_lang('Untitled');
- $this->params['course_code'] = isset($params['course_code']) ? $params['course_code'] : api_get_course_id();
- $this->params['add_signatures'] = isset($params['add_signatures']) ? $params['add_signatures'] : false;
- $this->pdf = new mPDF('UTF-8', $page_format, '', '', $params['left'], $params['right'], $params['top'], $params['bottom'], 8, 8, $orientation);
- }
- /**
- * Export the given HTML to PDF, using a global template
- * @param string the HTML content
- * @uses export/table_pdf.tpl
- */
- function html_to_pdf_with_template($content)
- {
- Display :: display_no_header();
- //Assignments
- Display::$global_template->assign('pdf_content', $content);
- $organization = api_get_setting('Institution');
- $img = api_get_path(SYS_CODE_PATH) . 'css/' . api_get_visual_theme() . '/images/header-logo.png';
- if (file_exists($img)) {
- $img = api_get_path(WEB_CODE_PATH) . 'css/' . api_get_visual_theme() . '/images/header-logo.png';
- $organization = "<img src='$img'>";
- } else {
- if (!empty($organization)) {
- $organization = '<h2 align="left">' . $organization . '</h2>';
- }
- }
- Display::$global_template->assign('organization', $organization);
- //Showing only the current teacher/admin instead the all teacherlist name see BT#4080
- $user_info = api_get_user_info();
- $teacher_list = $user_info['complete_name'];
- $session_name = api_get_session_name(api_get_session_id());
- if (!empty($session_name)) {
- Display::$global_template->assign('pdf_session', $session_name);
- }
- Display::$global_template->assign('pdf_course', $this->params['course_code']);
- Display::$global_template->assign('pdf_date', api_format_date(api_get_utc_datetime(), DATE_TIME_FORMAT_LONG));
- Display::$global_template->assign('pdf_teachers', $teacher_list);
- Display::$global_template->assign('pdf_title', $this->params['pdf_title']);
- Display::$global_template->assign('add_signatures', $this->params['add_signatures']);
- //Getting template
- $tpl = Display::$global_template->get_template('export/table_pdf.tpl');
- $html = Display::$global_template->fetch($tpl);
- $html = api_utf8_encode($html);
- $css_file = api_get_path(TO_SYS, WEB_CSS_PATH) . '/print.css';
- $css = file_exists($css_file) ? @file_get_contents($css_file) : '';
- self::content_to_pdf($html, $css, $this->params['filename'], $this->params['course_code']);
- }
- /**
- * Converts HTML files to PDF
- * @param mixed could be an html file path or an array with paths example:
- /var/www/myfile.html or array('/myfile.html','myotherfile.html') or
- * even an indexed array with both 'title' and 'path' indexes for each element
- * like array(0=>array('title'=>'Hello','path'=>'file.html'),1=>array('title'=>'Bye','path'=>'file2.html'));
- * @param string pdf name
- * @param string course code (if you are using html that are located in the document tool you must provide this)
- * @param bool Whether to print the header, footer and watermark (true) or just the content (false)
- * @return void
- */
- public function html_to_pdf($html_file_array, $pdf_name = '', $course_code = null, $print_title = false, $complete_style = true)
- {
- if ($complete_style === false) {
- error_log(__FUNCTION__ . ' with no style');
- }
- if (empty($html_file_array)) {
- return false;
- }
- if (is_array($html_file_array)) {
- if (count($html_file_array) == 0) {
- return false;
- }
- } else {
- if (!file_exists($html_file_array)) {
- return false;
- }
- // Converting the string into an array
- $html_file_array = array($html_file_array);
- }
- $course_data = array();
- if (!empty($course_code)) {
- $course_data = api_get_course_info($course_code);
- } else {
- $course_data = api_get_course_info();
- }
- //clean styles and javascript document
- $clean_search = array(
- '@<script[^>]*?>.*?</script>@si',
- '@<style[^>]*?>.*?</style>@si'
- );
- //Formatting the pdf
- self::format_pdf($course_data, $complete_style);
- $counter = 1;
- foreach ($html_file_array as $file) {
- //Add a page break per file
- $page_break = '<pagebreak>';
- if ($counter == count($html_file_array)) {
- $page_break = '';
- }
- $counter++;
- $html_title = '';
- //if the array provided contained subarrays with 'title' entry,
- // then print the title in the PDF
- if (is_array($file) && isset($file['title'])) {
- $html_title = $file['title'];
- $file = $file['path'];
- } else {
- // We suppose we've only been sent a file path.
- $html_title = basename($file);
- }
- if (empty($file) && !empty($html_title)) {
- //this is a chapter, print title & skip the rest
- if ($print_title) {
- $this->pdf->WriteHTML('<html><body><h3>' . $html_title . '</h3></body></html>' . $page_break, 2);
- }
- continue;
- }
- if (!file_exists($file)) {
- //the file doesn't exist, skip
- continue;
- }
- //it's not a chapter but the file exists, print its title
- if ($print_title) {
- $this->pdf->WriteHTML('<html><body><h3>' . $html_title . '</h3></body></html>', 2);
- }
- $file_info = pathinfo($file);
- $extension = $file_info['extension'];
- if (in_array($extension, array('html', 'htm'))) {
- $filename = $file_info['basename'];
- $filename = str_replace('_', ' ', $filename);
- if ($extension == 'html') {
- $filename = basename($filename, '.html');
- } elseif ($extension == 'htm') {
- $filename = basename($filename, '.htm');
- }
- $document_html = @file_get_contents($file);
- $document_html = preg_replace($clean_search, '', $document_html);
- //absolute path for frames.css //TODO: necessary?
- $absolute_css_path = api_get_path(WEB_CODE_PATH) . 'css/' . api_get_setting('stylesheets') . '/frames.css';
- $document_html = str_replace('href="./css/frames.css"', $absolute_css_path, $document_html);
- if (!empty($course_data['path'])) {
- $document_html = str_replace('../', '', $document_html);
- $document_path = api_get_path(SYS_COURSE_PATH) . $course_data['path'] . '/document/';
- $doc = new DOMDocument();
- $result = @$doc->loadHTML($document_html);
- //Fixing only images @todo do the same thing with other elements
- $elements = $doc->getElementsByTagName('img');
- if (!empty($elements)) {
- foreach ($elements as $item) {
- $old_src = $item->getAttribute('src');
- if (strpos($old_src, 'http') === false) {
- if (strpos($old_src, '/main/default_course_document') === false) {
- $old_src_fixed = '';
- if (api_get_path(REL_PATH) != '/') {
- $old_src_fixed = str_replace(api_get_path(REL_PATH) . 'courses/' . $course_data['path'] . '/document/', '', $old_src);
- } else {
- $old_src_fixed = str_replace('courses/' . $course_data['path'] . '/document/', '', $old_src);
- }
- $new_path = $document_path . $old_src_fixed;
- $document_html = str_replace($old_src, $new_path, $document_html);
- }
- } else {
- //Check if this is a complete URL
- /*if (strpos($old_src, 'courses/'.$course_data['path'].'/document/') === false) {
- } else {
- $old_src_fixed = str_replace(api_get_path(SYS_COURSE_PATH).$course_data['path'].'/document/', '', $old_src);
- $new_path = $document_path.$old_src_fixed;
- $document_html= str_replace($old_src, $new_path, $document_html);
- }*/
- }
- }
- }
- }
- Text::api_set_encoding_html($document_html, 'UTF-8'); // The library mPDF expects UTF-8 encoded input data.
- $title = Text::api_get_title_html($document_html, 'UTF-8', 'UTF-8'); // TODO: Maybe it is better idea the title to be passed through
- // $_GET[] too, as it is done with file name.
- // At the moment the title is retrieved from the html document itself.
- //echo $document_html;exit;
- if (empty($title)) {
- $title = $filename; // Here file name is expected to contain ASCII symbols only.
- }
- if (!empty($document_html)) {
- $this->pdf->WriteHTML($document_html . $page_break, 2);
- }
- } elseif (in_array($extension, array('jpg', 'jpeg', 'png', 'gif'))) {
- //Images
- $image = Display::img($file);
- $this->pdf->WriteHTML('<html><body>' . $image . '</body></html>' . $page_break, 2);
- }
- }
- if (empty($pdf_name)) {
- $output_file = 'pdf_' . date('Y-m-d-his') . '.pdf';
- } else {
- $pdf_name = api_replace_dangerous_char($pdf_name);
- $output_file = $pdf_name . '.pdf';
- }
- $result = $this->pdf->Output($output_file, 'D'); /// F to save the pdf in a file
- exit;
- }
- /**
- * Converts an html string to PDF
- * @param string valid html
- * @param string CSS content of a CSS file
- * @param string pdf name
- * @param string course code (if you are using html that are located in the document tool you must provide this)
- * @return string Web path
- */
- public function content_to_pdf($document_html, $css = '', $pdf_name = '', $course_code = null)
- {
- if (empty($document_html)) {
- return false;
- }
- //clean styles and javascript document
- $clean_search = array(
- '@<script[^>]*?>.*?</script>@si',
- '@<style[^>]*?>.*?</style>@siU'
- );
- //Formatting the pdf
- $course_data = api_get_course_info($course_code);
- self::format_pdf($course_data);
- $document_html = preg_replace($clean_search, '', $document_html);
- //absolute path for frames.css //TODO: necessary?
- $absolute_css_path = api_get_path(WEB_CODE_PATH) . 'css/' . api_get_setting('stylesheets') . '/frames.css';
- $document_html = str_replace('href="./css/frames.css"', 'href="' . $absolute_css_path . '"', $document_html);
- //$document_html=str_replace('<link rel="stylesheet" http://my.chamilo.net/main/css/chamilo/frames.css type="text/css" />','', $document_html);
- $document_html = str_replace('../../', '', $document_html);
- $document_html = str_replace('../', '', $document_html);
- $document_html = str_replace('courses/' . $course_code . '/document/', '', $document_html);
- if (!empty($course_data['path'])) {
- $document_path = api_get_path(SYS_COURSE_PATH) . $course_data['path'] . '/document/';
- $doc = new DOMDocument();
- $result = @$doc->loadHTML($document_html);
- //Fixing only images @todo do the same thing with other elements
- $elements = $doc->getElementsByTagName('img');
- if (!empty($elements)) {
- foreach ($elements as $item) {
- $old_src = $item->getAttribute('src');
- //$old_src= str_replace('../','',$old_src);
- if (strpos($old_src, 'http') === false) {
- if (strpos($old_src, '/main/default_course_document') === false) {
- if (strpos($old_src, '/main/inc/lib/') === false) {
- $old_src_fixed = str_replace('/courses/' . $course_data['path'] . '/document/', '', $old_src);
- $old_src_fixed = str_replace('courses/' . $course_data['path'] . '/document/', '', $old_src_fixed);
- $new_path = $document_path . $old_src_fixed;
- $document_html = str_replace($old_src, $new_path, $document_html);
- }
- }
- }
- }
- }
- }
- //replace relative path by absolute path for resources
- //$document_html= str_replace('src="/chamilo/main/default_course_document/', 'temp_template_path', $document_html);// before save src templates not apply
- //$document_html= str_replace('src="/', 'temp_template_path', $document_html);// before save src templates not apply
- //$document_html= str_replace('src="/chamilo/main/default_course_document/', 'temp_template_path', $document_html);// before save src templates not apply
- //$src_http_www= 'src="'.api_get_path(WEB_COURSE_PATH).$course_data['path'].'/document/';
- //$document_html= str_replace('src="',$src_http_www, $document_html);
- //$document_html= str_replace('temp_template_path', 'src="/main/default_course_document/', $document_html);// restore src templates
- Text::api_set_encoding_html($document_html, 'UTF-8'); // The library mPDF expects UTF-8 encoded input data.
- if (!empty($css)) {
- $this->pdf->WriteHTML($css, 1);
- }
- $this->pdf->WriteHTML($document_html, 2);
- if (empty($pdf_name)) {
- $output_file = 'pdf_' . date('Y-m-d-his') . '.pdf';
- } else {
- $pdf_name = api_replace_dangerous_char($pdf_name);
- $output_file = $pdf_name . '.pdf';
- }
- $result = $this->pdf->Output($output_file, 'D'); // F to save the pdf in a file
- exit;
- }
- /**
- * Gets the watermark from the platform or a course
- * @param string course code (optional)
- * @param mixed web path of the watermark image, false if there is nothing to return
- */
- public static function get_watermark($course_code = null)
- {
- $web_path = false;
- if (!empty($course_code) && api_get_setting('pdf_export_watermark_by_course') == 'true') {
- $course_info = api_get_course_info($course_code);
- $store_path = api_get_path(SYS_COURSE_PATH) . $course_info['path'] . '/' . api_get_current_access_url_id() . '_pdf_watermark.png'; // course path
- if (file_exists($store_path)) {
- $web_path = api_get_path(WEB_COURSE_PATH) . $course_info['path'] . '/' . api_get_current_access_url_id() . '_pdf_watermark.png';
- }
- } else {
- $store_path = api_get_path(SYS_DEFAULT_COURSE_DOCUMENT_PATH).'images/' . api_get_current_access_url_id() . '_pdf_watermark.png'; // course path
- if (file_exists($store_path))
- $web_path = api_get_path(SYS_DEFAULT_COURSE_DOCUMENT_PATH).'images/' . api_get_current_access_url_id() . '_pdf_watermark.png';
- }
- return $web_path;
- }
- /**
- * Deletes the watermark from the Platform or Course
- * @param string course code (optional)
- * @param mixed web path of the watermark image, false if there is nothing to return
- */
- public function delete_watermark($course_code = null)
- {
- if (!empty($course_code) && api_get_setting('pdf_export_watermark_by_course') == 'true') {
- $course_info = api_get_course_info($course_code);
- $store_path = api_get_path(SYS_COURSE_PATH) . $course_info['path'] . '/' . api_get_current_access_url_id() . '_pdf_watermark.png'; // course path
- } else {
- $store_path = api_get_path(SYS_DEFAULT_COURSE_DOCUMENT_PATH).'default_course_document/'.api_get_current_access_url_id().'_pdf_watermark.png'; // course path
- }
- if (file_exists($store_path)) {
- @unlink($store_path);
- return true;
- }
- return false;
- }
- /**
- * Uploads the pdf watermark in the main/default_course_document directory or in the course directory
- * @param string filename
- * @param string path of the file
- * @param string course code
- * @return mixed web path of the file if sucess, false otherwise
- */
- public function upload_watermark($filename, $source_file, $course_code = null)
- {
- if (!empty($course_code) && api_get_setting('pdf_export_watermark_by_course') == 'true') {
- $course_info = api_get_course_info($course_code);
- $store_path = api_get_path(SYS_COURSE_PATH) . $course_info['path']; // course path
- $web_path = api_get_path(WEB_COURSE_PATH) . $course_info['path'] . '/pdf_watermark.png';
- } else {
- $store_path = api_get_path(SYS_DEFAULT_COURSE_DOCUMENT_PATH).'images'; // course path
- $web_path = api_get_path(WEB_DEFAULT_COURSE_DOCUMENT_PATH).'images/' . api_get_current_access_url_id() . '_pdf_watermark.png';
- }
- $course_image = $store_path . '/' . api_get_current_access_url_id() . '_pdf_watermark.png';
- $extension = strtolower(substr(strrchr($filename, '.'), 1));
- $result = false;
- if (file_exists($course_image)) {
- @unlink($course_image);
- }
- $my_image = new Image($source_file);
- $result = $my_image->send_image($course_image, -1, 'png');
- if ($result) {
- $result = $web_path;
- }
- return $result;
- }
- /**
- * Returns the default header
- */
- public function get_header($course_code = null)
- {
- /*$header = api_get_setting('pdf_export_watermark_text');
- if (!empty($course_code) && api_get_setting('pdf_export_watermark_by_course') == 'true') {
- $header = api_get_course_setting('pdf_export_watermark_text');
- }
- return $header;*/
- }
- public function set_footer()
- {
- $this->pdf->defaultfooterfontsize = 12; // in pts
- $this->pdf->defaultfooterfontstyle = B; // blank, B, I, or BI
- $this->pdf->defaultfooterline = 1; // 1 to include line below header/above footer
- $platform_name = api_get_setting('Institution');
- $left_content = $platform_name;
- $center_content = '';
- $right_content = '{PAGENO} / {nb}';
- //@todo remove this and use a simpler way
- $footer = array(
- 'odd' => array(
- 'L' => array(
- 'content' => $left_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'C' => array(
- 'content' => $center_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'R' => array(
- 'content' => $right_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'line' => 1,
- ),
- 'even' => array(
- 'L' => array(
- 'content' => $left_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'C' => array(
- 'content' => $center_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'R' => array(
- 'content' => $right_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'line' => 1,
- ),
- );
- // defines footer for Odd and Even Pages - placed at Outer margin see http://mpdf1.com/manual/index.php?tid=151&searchstring=setfooter
- $this->pdf->SetFooter($footer);
- }
- public function set_header($course_data)
- {
- $this->pdf->defaultheaderfontsize = 10; // in pts
- $this->pdf->defaultheaderfontstyle = BI; // blank, B, I, or BI
- $this->pdf->defaultheaderline = 1; // 1 to include line below header/above footer
- if (!empty($course_data['code'])) {
- $teacher_list = CourseManager::get_teacher_list_from_course_code($course_data['code']);
- $teachers = '';
- if (!empty($teacher_list)) {
- foreach ($teacher_list as $teacher) {
- //$teachers[]= api_get_person_name($teacher['firstname'], $teacher['lastname']);
- $teachers[] = $teacher['firstname'] . ' ' . $teacher['lastname'];
- }
- if (count($teachers) > 1) {
- $teachers = get_lang('Teachers') . ': ' . implode(', ', $teachers);
- } else {
- $teachers = get_lang('Teacher') . ': ' . implode('', $teachers);
- }
- //do not show the teacher list see BT#4080 only the current teacher name
- $user_info = api_get_user_info();
- $teachers = $user_info['complete_name'];
- }
- $left_content = '';
- $center_content = '';
- $right_content = $teachers;
- $header = array(
- 'odd' => array(
- 'L' => array(
- 'content' => $left_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'C' => array(
- 'content' => $center_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'R' => array(
- 'content' => $right_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'line' => 1,
- ),
- 'even' => array(
- 'L' => array(
- 'content' => $left_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'C' => array(
- 'content' => $center_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'R' => array(
- 'content' => $right_content, 'font-size' => 10, 'font-style' => 'B', 'font-family' => 'serif', 'color' => '#000000'),
- 'line' => 1,
- ),
- );
- $this->pdf->SetHeader($header); // ('{DATE j-m-Y}|{PAGENO}/{nb}|'.$title);
- }
- }
- public function set_custom_header($header)
- {
- $this->custom_header = $header;
- }
- public function set_custom_footer($footer)
- {
- $this->custom_footer = $footer;
- }
- /**
- * Pre-formats a PDF to the right size and, if not stated otherwise, with
- * header, footer and watermark (if any)
- * @param array General course information (to fill headers)
- * @param bool Whether we want headers, footers and watermark or not
- */
- public function format_pdf($course_data, $complete = true)
- {
- if ($complete === false) {
- error_log('Asked with no decoration');
- }
- $course_code = null;
- if (!empty($course_data)) {
- $course_code = $course_data['code'];
- }
- /*$pdf->SetAuthor('Documents Chamilo');
- $pdf->SetTitle('title');
- $pdf->SetSubject('Exported from Chamilo Documents');
- $pdf->SetKeywords('Chamilo Documents');
- */
- $this->pdf->directionality = api_get_text_direction(); // TODO: To be read from the html document.
- $this->pdf->useOnlyCoreFonts = true;
- $this->pdf->mirrorMargins = 1; // Use different Odd/Even headers and footers and mirror margins
- // Add decoration only if not stated otherwise
- if ($complete) {
- //Adding watermark
- if (api_get_setting('pdf_export_watermark_enable') == 'true') {
- $watermark_file = self::get_watermark($course_code);
- if ($watermark_file) {
- //http://mpdf1.com/manual/index.php?tid=269&searchstring=watermark
- $this->pdf->SetWatermarkImage($watermark_file);
- $this->pdf->showWatermarkImage = true;
- } else {
- $watermark_file = self::get_watermark(null);
- if ($watermark_file) {
- $this->pdf->SetWatermarkImage($watermark_file);
- $this->pdf->showWatermarkImage = true;
- }
- }
- if ($course_code) {
- $watermark_text = api_get_course_setting('pdf_export_watermark_text');
- if (empty($watermark_text)) {
- $watermark_text = api_get_setting('pdf_export_watermark_text');
- }
- } else {
- $watermark_text = api_get_setting('pdf_export_watermark_text');
- }
- if (!empty($watermark_text)) {
- $this->pdf->SetWatermarkText(strcode2utf($watermark_text), 0.1);
- $this->pdf->showWatermarkText = true;
- }
- }
- if (empty($this->custom_header)) {
- self::set_header($course_data);
- } else {
- $this->pdf->SetHTMLHeader($this->custom_header, 'E');
- $this->pdf->SetHTMLHeader($this->custom_header, 'O');
- }
- if (empty($this->custom_footer)) {
- self::set_footer();
- } else {
- $this->pdf->SetHTMLFooter($this->custom_footer);
- }
- }
- }
- }
|