1a876b55bSAndreas Gohr<?php 2a876b55bSAndreas Gohr/** 3a876b55bSAndreas Gohr * DokuWiki Plugin dw2pdf (Renderer Component) 4a876b55bSAndreas Gohr * 5a876b55bSAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 6a876b55bSAndreas Gohr * @author Andreas Gohr <gohr@cosmocode.de> 7a876b55bSAndreas Gohr */ 8a876b55bSAndreas Gohr 9a876b55bSAndreas Gohr// must be run within Dokuwiki 10a876b55bSAndreas Gohrif (!defined('DOKU_INC')) die(); 11a876b55bSAndreas Gohr 1260e59de7SGerrit Uitslag/** 1360e59de7SGerrit Uitslag * Render xhtml suitable as input for mpdf library 1460e59de7SGerrit Uitslag */ 15a876b55bSAndreas Gohrclass renderer_plugin_dw2pdf extends Doku_Renderer_xhtml { 16a876b55bSAndreas Gohr 17475fd248SIvan Poliakov private $lastheadlevel = -1; 18475fd248SIvan Poliakov private $current_bookmark_level = 0; 1960e59de7SGerrit Uitslag /** 2060e59de7SGerrit Uitslag * Stores action instance 2160e59de7SGerrit Uitslag * 2260e59de7SGerrit Uitslag * @var action_plugin_dw2pdf 2360e59de7SGerrit Uitslag */ 2460e59de7SGerrit Uitslag private $actioninstance = null; 2560e59de7SGerrit Uitslag 2660e59de7SGerrit Uitslag /** 2760e59de7SGerrit Uitslag * load action plugin instance 2860e59de7SGerrit Uitslag */ 2960e59de7SGerrit Uitslag public function __construct() { 3060e59de7SGerrit Uitslag $this->actioninstance = plugin_load('action', 'dw2pdf'); 3160e59de7SGerrit Uitslag } 3260e59de7SGerrit Uitslag 3360e59de7SGerrit Uitslag public function document_start() { 3460e59de7SGerrit Uitslag global $ID; 3560e59de7SGerrit Uitslag 3660e59de7SGerrit Uitslag parent::document_start(); 3760e59de7SGerrit Uitslag 3860e59de7SGerrit Uitslag //ancher for rewritten links to included pages 3960e59de7SGerrit Uitslag $check = false; 4060e59de7SGerrit Uitslag $pid = sectionID($ID, $check); 4160e59de7SGerrit Uitslag 4260e59de7SGerrit Uitslag $this->doc .= "<a name=\"{$pid}__\">"; 4360e59de7SGerrit Uitslag $this->doc .= "</a>"; 4460e59de7SGerrit Uitslag } 4583bac986SAndreas Gohr 46a876b55bSAndreas Gohr /** 47a876b55bSAndreas Gohr * Make available as XHTML replacement renderer 48*236e9da2SGerrit Uitslag * 49*236e9da2SGerrit Uitslag * @param $format 50*236e9da2SGerrit Uitslag * @return bool 51a876b55bSAndreas Gohr */ 52a876b55bSAndreas Gohr public function canRender($format){ 53a876b55bSAndreas Gohr if($format == 'xhtml') return true; 54a876b55bSAndreas Gohr return false; 55a876b55bSAndreas Gohr } 56a876b55bSAndreas Gohr 57a876b55bSAndreas Gohr /** 58a876b55bSAndreas Gohr * Simplified header printing with PDF bookmarks 59*236e9da2SGerrit Uitslag * 60*236e9da2SGerrit Uitslag * @param string $text 61*236e9da2SGerrit Uitslag * @param int $level 62*236e9da2SGerrit Uitslag * @param int $pos 63a876b55bSAndreas Gohr */ 64a876b55bSAndreas Gohr function header($text, $level, $pos) { 65a876b55bSAndreas Gohr if(!$text) return; //skip empty headlines 6660e59de7SGerrit Uitslag global $ID; 67a876b55bSAndreas Gohr 68244aaa51SMichael Hamann $hid = $this->_headerToLink($text, true); 6957a1b6f9SGerrit Uitslag 7057a1b6f9SGerrit Uitslag //only add items within global configured levels (doesn't check the pdf toc settings) 7157a1b6f9SGerrit Uitslag $this->toc_additem($hid, $text, $level); 7257a1b6f9SGerrit Uitslag 7360e59de7SGerrit Uitslag $check = false; 7460e59de7SGerrit Uitslag $pid = sectionID($ID, $check); 7560e59de7SGerrit Uitslag $hid = $pid . '__' . $hid; 76244aaa51SMichael Hamann 77a876b55bSAndreas Gohr // add PDF bookmark 787fa15500SAndreas Gohr $bookmark = ''; 7902f9a447SGerrit Uitslag $bmlevel = $this->actioninstance->getExportConfig('maxbookmarks'); 80a876b55bSAndreas Gohr if($bmlevel && $bmlevel >= $level){ 8183bac986SAndreas Gohr // PDF readers choke on invalid nested levels 82475fd248SIvan Poliakov 83475fd248SIvan Poliakov if ($this->lastheadlevel == -1) 8483bac986SAndreas Gohr $this->lastheadlevel = $level; 8583bac986SAndreas Gohr 86475fd248SIvan Poliakov $step = $level - $this->lastheadlevel; 87475fd248SIvan Poliakov 88475fd248SIvan Poliakov if ($step > 0) 89475fd248SIvan Poliakov $this->current_bookmark_level += 1; 90475fd248SIvan Poliakov else if ($step <0) { 91475fd248SIvan Poliakov $this->current_bookmark_level -= 1; 92475fd248SIvan Poliakov if ($this->current_bookmark_level < 0) 93475fd248SIvan Poliakov $this->current_bookmark_level = 0; 94475fd248SIvan Poliakov } 95475fd248SIvan Poliakov 96475fd248SIvan Poliakov $this->lastheadlevel = $level; 97475fd248SIvan Poliakov 987fa15500SAndreas Gohr $bookmark = '<bookmark content="'.$this->_xmlEntities($text).'" level="'.($this->current_bookmark_level).'" />'; 99a876b55bSAndreas Gohr } 100a876b55bSAndreas Gohr 101a876b55bSAndreas Gohr // print header 1027fa15500SAndreas Gohr $this->doc .= DOKU_LF."<h$level>$bookmark"; 103244aaa51SMichael Hamann $this->doc .= "<a name=\"$hid\">"; 104a876b55bSAndreas Gohr $this->doc .= $this->_xmlEntities($text); 105244aaa51SMichael Hamann $this->doc .= "</a>"; 106a876b55bSAndreas Gohr $this->doc .= "</h$level>".DOKU_LF; 107a876b55bSAndreas Gohr } 108a876b55bSAndreas Gohr 109aab792a5SAndreas Gohr /** 11060e59de7SGerrit Uitslag * Render a page local link 11160e59de7SGerrit Uitslag * 112*236e9da2SGerrit Uitslag * // modified copy of parent function 113*236e9da2SGerrit Uitslag * 11460e59de7SGerrit Uitslag * @param string $hash hash link identifier 11560e59de7SGerrit Uitslag * @param string $name name for the link 116*236e9da2SGerrit Uitslag * @param bool $returnonly 117*236e9da2SGerrit Uitslag * @return string|void 11860e59de7SGerrit Uitslag * 11960e59de7SGerrit Uitslag * @see Doku_Renderer_xhtml::locallink 12060e59de7SGerrit Uitslag */ 121528811ffSAnael Mobilia function locallink($hash, $name = null, $returnonly = false) { 12260e59de7SGerrit Uitslag global $ID; 12360e59de7SGerrit Uitslag $name = $this->_getLinkTitle($name, $hash, $isImage); 12460e59de7SGerrit Uitslag $hash = $this->_headerToLink($hash); 12560e59de7SGerrit Uitslag $title = $ID.' ↵'; 12660e59de7SGerrit Uitslag 12760e59de7SGerrit Uitslag $check = false; 12860e59de7SGerrit Uitslag $pid = sectionID($ID, $check); 12960e59de7SGerrit Uitslag 13060e59de7SGerrit Uitslag $this->doc .= '<a href="#'. $pid . '__' . $hash.'" title="'.$title.'" class="wikilink1">'; 13160e59de7SGerrit Uitslag $this->doc .= $name; 13260e59de7SGerrit Uitslag $this->doc .= '</a>'; 13360e59de7SGerrit Uitslag } 13460e59de7SGerrit Uitslag 13560e59de7SGerrit Uitslag /** 136aab792a5SAndreas Gohr * Wrap centered media in a div to center it 137*236e9da2SGerrit Uitslag * 138*236e9da2SGerrit Uitslag * @param string $src media ID 139*236e9da2SGerrit Uitslag * @param string $title descriptive text 140*236e9da2SGerrit Uitslag * @param string $align left|center|right 141*236e9da2SGerrit Uitslag * @param int $width width of media in pixel 142*236e9da2SGerrit Uitslag * @param int $height height of media in pixel 143*236e9da2SGerrit Uitslag * @param string $cache cache|recache|nocache 144*236e9da2SGerrit Uitslag * @param bool $render should the media be embedded inline or just linked 145*236e9da2SGerrit Uitslag * @return string 146aab792a5SAndreas Gohr */ 147aab792a5SAndreas Gohr function _media ($src, $title=NULL, $align=NULL, $width=NULL, 148aab792a5SAndreas Gohr $height=NULL, $cache=NULL, $render = true) { 149aab792a5SAndreas Gohr 150aab792a5SAndreas Gohr $out = ''; 151aab792a5SAndreas Gohr if($align == 'center'){ 152aab792a5SAndreas Gohr $out .= '<div align="center" style="text-align: center">'; 153aab792a5SAndreas Gohr } 154aab792a5SAndreas Gohr 155aab792a5SAndreas Gohr $out .= parent::_media ($src, $title, $align, $width, $height, $cache, $render); 156aab792a5SAndreas Gohr 157aab792a5SAndreas Gohr if($align == 'center'){ 158aab792a5SAndreas Gohr $out .= '</div>'; 159aab792a5SAndreas Gohr } 160aab792a5SAndreas Gohr 161aab792a5SAndreas Gohr return $out; 162aab792a5SAndreas Gohr } 163aab792a5SAndreas Gohr 164551dd41eSAndreas Gohr /** 165551dd41eSAndreas Gohr * hover info makes no sense in PDFs, so drop acronyms 166*236e9da2SGerrit Uitslag * 167*236e9da2SGerrit Uitslag * @param string $acronym 168551dd41eSAndreas Gohr */ 169551dd41eSAndreas Gohr function acronym($acronym) { 170551dd41eSAndreas Gohr $this->doc .= $this->_xmlEntities($acronym); 171551dd41eSAndreas Gohr } 172551dd41eSAndreas Gohr 1739eb4c81fSAndreas Gohr /** 1749eb4c81fSAndreas Gohr * reformat links if needed 175*236e9da2SGerrit Uitslag * 176*236e9da2SGerrit Uitslag * @param array $link 177*236e9da2SGerrit Uitslag * @return string 1789eb4c81fSAndreas Gohr */ 1799eb4c81fSAndreas Gohr function _formatLink($link){ 18060e59de7SGerrit Uitslag 18160e59de7SGerrit Uitslag // for internal links contains the title the pageid 18260e59de7SGerrit Uitslag if(in_array($link['title'], $this->actioninstance->getExportedPages())) { 18360e59de7SGerrit Uitslag list(/* $url */, $hash) = explode('#', $link['url'], 2); 18460e59de7SGerrit Uitslag 18560e59de7SGerrit Uitslag $check = false; 18660e59de7SGerrit Uitslag $pid = sectionID($link['title'], $check); 18760e59de7SGerrit Uitslag $link['url'] = "#" . $pid . '__' . $hash; 18860e59de7SGerrit Uitslag } 18960e59de7SGerrit Uitslag 19060e59de7SGerrit Uitslag 1919eb4c81fSAndreas Gohr // prefix interwiki links with interwiki icon 1929eb4c81fSAndreas Gohr if($link['name'][0] != '<' && preg_match('/\binterwiki iw_(.\w+)\b/',$link['class'],$m)){ 1939eb4c81fSAndreas Gohr if(file_exists(DOKU_INC.'lib/images/interwiki/'.$m[1].'.png')){ 1949eb4c81fSAndreas Gohr $img = DOKU_BASE.'lib/images/interwiki/'.$m[1].'.png'; 1959eb4c81fSAndreas Gohr }elseif(file_exists(DOKU_INC.'lib/images/interwiki/'.$m[1].'.gif')){ 1969eb4c81fSAndreas Gohr $img = DOKU_BASE.'lib/images/interwiki/'.$m[1].'.gif'; 1979eb4c81fSAndreas Gohr }else{ 1989eb4c81fSAndreas Gohr $img = DOKU_BASE.'lib/images/interwiki.png'; 1999eb4c81fSAndreas Gohr } 2009eb4c81fSAndreas Gohr 20147b0d67bSAndreas Gohr $link['name'] = '<img src="'.$img.'" width="16" height="16" style="vertical-align: center" class="'.$link['class'].'" />'.$link['name']; 2029eb4c81fSAndreas Gohr } 2039eb4c81fSAndreas Gohr return parent::_formatLink($link); 2049eb4c81fSAndreas Gohr } 205ccdd3126SAndreas Gohr 206ccdd3126SAndreas Gohr /** 207ccdd3126SAndreas Gohr * no obfuscation for email addresses 208*236e9da2SGerrit Uitslag * 209*236e9da2SGerrit Uitslag * @param string $address 210*236e9da2SGerrit Uitslag * @param null $name 211*236e9da2SGerrit Uitslag * @param bool $returnonly 212*236e9da2SGerrit Uitslag * @return string|void 213ccdd3126SAndreas Gohr */ 2140a23c2bcSAnael Mobilia function emaillink($address, $name = NULL, $returnonly = false) { 215ccdd3126SAndreas Gohr global $conf; 216ccdd3126SAndreas Gohr $old = $conf['mailguard']; 217ccdd3126SAndreas Gohr $conf['mailguard'] = 'none'; 2189e1a2ac6SAnael Mobilia parent::emaillink($address, $name, $returnonly); 219ccdd3126SAndreas Gohr $conf['mailguard'] = $old; 220ccdd3126SAndreas Gohr } 221ccdd3126SAndreas Gohr 222a876b55bSAndreas Gohr} 223a876b55bSAndreas Gohr 224