1ed7b5f09Sandi<?php 215fae107Sandi/** 315fae107Sandi * HTML output functions 415fae107Sandi * 515fae107Sandi * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 715fae107Sandi */ 815fae107Sandi 979a2d784SGerrit Uitslaguse dokuwiki\Action\Denied; 1079a2d784SGerrit Uitslaguse dokuwiki\Action\Locked; 110c3a5702SAndreas Gohruse dokuwiki\ChangeLog\PageChangeLog; 12e1d9dcc8SAndreas Gohruse dokuwiki\Extension\AuthPlugin; 13cbb44eabSAndreas Gohruse dokuwiki\Extension\Event; 1479a2d784SGerrit Uitslaguse dokuwiki\Ui\Backlinks; 1579a2d784SGerrit Uitslaguse dokuwiki\Ui\Editor; 1679a2d784SGerrit Uitslaguse dokuwiki\Ui\Index; 1779a2d784SGerrit Uitslaguse dokuwiki\Ui\Login; 1879a2d784SGerrit Uitslaguse dokuwiki\Ui\PageConflict; 1979a2d784SGerrit Uitslaguse dokuwiki\Ui\PageDiff; 2079a2d784SGerrit Uitslaguse dokuwiki\Ui\PageDraft; 2179a2d784SGerrit Uitslaguse dokuwiki\Ui\PageRevisions; 2279a2d784SGerrit Uitslaguse dokuwiki\Ui\PageView; 2379a2d784SGerrit Uitslaguse dokuwiki\Ui\Recent; 2479a2d784SGerrit Uitslaguse dokuwiki\Ui\UserProfile; 2579a2d784SGerrit Uitslaguse dokuwiki\Ui\UserRegister; 2679a2d784SGerrit Uitslaguse dokuwiki\Ui\UserResendPwd; 2779a2d784SGerrit Uitslaguse dokuwiki\Utf8\Clean; 280c3a5702SAndreas Gohr 292d3b082eSMichael Großeif (!defined('SEC_EDIT_PATTERN')) { 3037c80e0eSLarsDW223 define('SEC_EDIT_PATTERN', '#<!-- EDIT({.*?}) -->#'); 312d3b082eSMichael Große} 322d3b082eSMichael Große 336bbae538Sandi 34f3f0262cSandi/** 35f3f0262cSandi * Convenience function to quickly build a wikilink 3615fae107Sandi * 3715fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 388d5e837eSMichael Hamann * @param string $id id of the target page 398d5e837eSMichael Hamann * @param string $name the name of the link, i.e. the text that is displayed 408d5e837eSMichael Hamann * @param string|array $search search string(s) that shall be highlighted in the target page 418d5e837eSMichael Hamann * @return string the HTML code of the link 42f3f0262cSandi */ 43db959ae3SAndreas Gohrfunction html_wikilink($id, $name = null, $search = '') { 44a8397511SGerrit Uitslag /** @var Doku_Renderer_xhtml $xhtml_renderer */ 45db959ae3SAndreas Gohr static $xhtml_renderer = null; 46723d78dbSandi if (is_null($xhtml_renderer)) { 477aea91afSChris Smith $xhtml_renderer = p_get_renderer('xhtml'); 48f3f0262cSandi } 49f3f0262cSandi 50fe9ec250SChris Smith return $xhtml_renderer->internallink($id,$name,$search,true,'navigation'); 51f3f0262cSandi} 52f3f0262cSandi 53f3f0262cSandi/** 54f3f0262cSandi * The loginform 5515fae107Sandi * 5615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 57d1d904bbSMichael Große * 58d1d904bbSMichael Große * @param bool $svg Whether to show svg icons in the register and resendpwd links or not 59bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 60f3f0262cSandi */ 61d1d904bbSMichael Großefunction html_login($svg = false) { 6279a2d784SGerrit Uitslag dbg_deprecated(Login::class .'::show()'); 63bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\Login($svg))->show(); 64f3f0262cSandi} 65f3f0262cSandi 66d59dea9fSGerrit Uitslag 67d59dea9fSGerrit Uitslag/** 68d59dea9fSGerrit Uitslag * Denied page content 69d59dea9fSGerrit Uitslag * 707afe5d93SSatoshi Sahara * @deprecated 2020-07-18 not called anymore, see inc/Action/Denied::tplContent() 71d59dea9fSGerrit Uitslag */ 72d59dea9fSGerrit Uitslagfunction html_denied() { 7379a2d784SGerrit Uitslag dbg_deprecated(Denied::class .'::showBanner()'); 74a215faf2SSatoshi Sahara (new dokuwiki\Action\Denied())->showBanner(); 75d59dea9fSGerrit Uitslag} 76d59dea9fSGerrit Uitslag 77f3f0262cSandi/** 7815fae107Sandi * inserts section edit buttons if wanted or removes the markers 7915fae107Sandi * 8015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 8142ea7f44SGerrit Uitslag * 8242ea7f44SGerrit Uitslag * @param string $text 8342ea7f44SGerrit Uitslag * @param bool $show show section edit buttons? 8442ea7f44SGerrit Uitslag * @return string 8515fae107Sandi */ 86f3f0262cSandifunction html_secedit($text, $show = true) { 87f3f0262cSandi global $INFO; 8835dae8b0SBen Coburn 89aac83cd4SPhy if ((isset($INFO) && !$INFO['writable']) || !$show || (isset($INFO) && $INFO['rev'])) { 902d3b082eSMichael Große return preg_replace(SEC_EDIT_PATTERN,'',$text); 91f3f0262cSandi } 9235dae8b0SBen Coburn 932d3b082eSMichael Große return preg_replace_callback(SEC_EDIT_PATTERN, 9440868f2fSAdrian Lang 'html_secedit_button', $text); 9540868f2fSAdrian Lang} 9640868f2fSAdrian Lang 9740868f2fSAdrian Lang/** 9840868f2fSAdrian Lang * prepares section edit button data for event triggering 9940868f2fSAdrian Lang * used as a callback in html_secedit 10040868f2fSAdrian Lang * 10140868f2fSAdrian Lang * @author Andreas Gohr <andi@splitbrain.org> 10242ea7f44SGerrit Uitslag * 10342ea7f44SGerrit Uitslag * @param array $matches matches with regexp 10442ea7f44SGerrit Uitslag * @return string 10542ea7f44SGerrit Uitslag * @triggers HTML_SECEDIT_BUTTON 10640868f2fSAdrian Lang */ 10740868f2fSAdrian Langfunction html_secedit_button($matches){ 108ada0d779SMichael Hamann $json = htmlspecialchars_decode($matches[1], ENT_QUOTES); 109ada0d779SMichael Hamann $data = json_decode($json, true); 110*96ebed36SAndreas Gohr if ($data === null) { 11179a2d784SGerrit Uitslag return ''; 11206917fceSMichael Große } 113ec57f119SLarsDW223 $data['target'] = strtolower($data['target']); 114*96ebed36SAndreas Gohr $data['hid'] = strtolower($data['hid'] ?? ''); 11540868f2fSAdrian Lang 116*96ebed36SAndreas Gohr return Event::createAndTrigger( 117*96ebed36SAndreas Gohr 'HTML_SECEDIT_BUTTON', 118*96ebed36SAndreas Gohr $data, 119*96ebed36SAndreas Gohr 'html_secedit_get_button' 120*96ebed36SAndreas Gohr ); 12140868f2fSAdrian Lang} 12240868f2fSAdrian Lang 12340868f2fSAdrian Lang/** 12440868f2fSAdrian Lang * prints a section editing button 12540868f2fSAdrian Lang * used as default action form HTML_SECEDIT_BUTTON 12640868f2fSAdrian Lang * 12740868f2fSAdrian Lang * @author Adrian Lang <lang@cosmocode.de> 12842ea7f44SGerrit Uitslag * 12942ea7f44SGerrit Uitslag * @param array $data name, section id and target 13042ea7f44SGerrit Uitslag * @return string html 13140868f2fSAdrian Lang */ 13240868f2fSAdrian Langfunction html_secedit_get_button($data) { 13340868f2fSAdrian Lang global $ID; 13440868f2fSAdrian Lang global $INFO; 13540868f2fSAdrian Lang 1366d9eab4dSMichael Hamann if (!isset($data['name']) || $data['name'] === '') return ''; 13740868f2fSAdrian Lang 13840868f2fSAdrian Lang $name = $data['name']; 13940868f2fSAdrian Lang unset($data['name']); 14040868f2fSAdrian Lang 141905fa971SAdrian Lang $secid = $data['secid']; 142905fa971SAdrian Lang unset($data['secid']); 143905fa971SAdrian Lang 1447afe5d93SSatoshi Sahara $params = array_merge( 1457afe5d93SSatoshi Sahara array('do' => 'edit', 'rev' => $INFO['lastmod'], 'summary' => '['.$name.'] '), 1467afe5d93SSatoshi Sahara $data 1477afe5d93SSatoshi Sahara ); 1487afe5d93SSatoshi Sahara 1497afe5d93SSatoshi Sahara $html = '<div class="secedit editbutton_'.$data['target'] .' editbutton_'.$secid .'">'; 1507afe5d93SSatoshi Sahara $html.= html_btn('secedit', $ID, '', $params, 'post', $name); 1517afe5d93SSatoshi Sahara $html.= '</div>'; 1527afe5d93SSatoshi Sahara return $html; 153f3f0262cSandi} 154f3f0262cSandi 155f3f0262cSandi/** 156d6c9c552Smatthiasgrimm * Just the back to top button (in its own form) 1576b13307fSandi * 1586b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 15942ea7f44SGerrit Uitslag * 16042ea7f44SGerrit Uitslag * @return string html 1616b13307fSandi */ 1626b13307fSandifunction html_topbtn() { 1636b13307fSandi global $lang; 1646b13307fSandi 16579a2d784SGerrit Uitslag return '<a class="nolink" href="#dokuwiki__top">' 1667afe5d93SSatoshi Sahara .'<button class="button" onclick="window.scrollTo(0, 0)" title="'. $lang['btn_top'] .'">' 1677afe5d93SSatoshi Sahara . $lang['btn_top'] 1687afe5d93SSatoshi Sahara .'</button></a>'; 1696b13307fSandi} 1706b13307fSandi 1716b13307fSandi/** 172d67ca2c0Smatthiasgrimm * Displays a button (using its own form) 17335dae8b0SBen Coburn * If tooltip exists, the access key tooltip is replaced. 17415fae107Sandi * 17515fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 17642ea7f44SGerrit Uitslag * 17742ea7f44SGerrit Uitslag * @param string $name 17842ea7f44SGerrit Uitslag * @param string $id 17942ea7f44SGerrit Uitslag * @param string $akey access key 180e3710957SGerrit Uitslag * @param string[] $params key-value pairs added as hidden inputs 18142ea7f44SGerrit Uitslag * @param string $method 18242ea7f44SGerrit Uitslag * @param string $tooltip 18342ea7f44SGerrit Uitslag * @param bool|string $label label text, false: lookup btn_$name in localization 184e824d633SMichael Große * @param string $svg (optional) svg code, inserted into the button 18542ea7f44SGerrit Uitslag * @return string 186f3f0262cSandi */ 187e824d633SMichael Großefunction html_btn($name, $id, $akey, $params, $method = 'get', $tooltip = '', $label = false, $svg = null) { 188f3f0262cSandi global $conf; 189f3f0262cSandi global $lang; 190f3f0262cSandi 191f5baf821SAnika Henke if (!$label) 192f3f0262cSandi $label = $lang['btn_'.$name]; 193f3f0262cSandi 19449c713a3Sandi //filter id (without urlencoding) 19549c713a3Sandi $id = idfilter($id,false); 196f3f0262cSandi 197f3f0262cSandi //make nice URLs even for buttons 1986c7843b5Sandi if ($conf['userewrite'] == 2) { 1996c7843b5Sandi $script = DOKU_BASE.DOKU_SCRIPT.'/'.$id; 2006c7843b5Sandi } elseif ($conf['userewrite']) { 2016c7843b5Sandi $script = DOKU_BASE.$id; 2026c7843b5Sandi } else { 2038b00ebcfSandi $script = DOKU_BASE.DOKU_SCRIPT; 204f3f0262cSandi $params['id'] = $id; 205f3f0262cSandi } 206f3f0262cSandi 2077afe5d93SSatoshi Sahara $html = '<form class="button btn_'.$name.'" method="'.$method.'" action="'.$script.'"><div class="no">'; 208f3f0262cSandi 20906a4bf8fSAndreas Gohr if (is_array($params)) { 2109e491c01SAndreas Gohr foreach ($params as $key => $val) { 2117afe5d93SSatoshi Sahara $html .= '<input type="hidden" name="'.$key.'" value="'.hsc($val).'" />'; 212f3f0262cSandi } 21306a4bf8fSAndreas Gohr } 214f3f0262cSandi 2157afe5d93SSatoshi Sahara $tip = empty($tooltip) ? hsc($label) : hsc($tooltip); 21611ea018fSAndreas Gohr 2177afe5d93SSatoshi Sahara $html .= '<button type="submit" '; 21811ea018fSAndreas Gohr if ($akey) { 21907493d05SAnika Henke $tip .= ' ['.strtoupper($akey).']'; 2207afe5d93SSatoshi Sahara $html .= 'accesskey="'.$akey.'" '; 22135dae8b0SBen Coburn } 2227afe5d93SSatoshi Sahara $html .= 'title="'.$tip.'">'; 223e824d633SMichael Große if ($svg) { 2247afe5d93SSatoshi Sahara $html .= '<span>'. hsc($label) .'</span>'. inlineSVG($svg); 225679dba01SMichael Große } else { 2267afe5d93SSatoshi Sahara $html .= hsc($label); 227679dba01SMichael Große } 2287afe5d93SSatoshi Sahara $html .= '</button>'; 2297afe5d93SSatoshi Sahara $html .= '</div></form>'; 230f3f0262cSandi 2317afe5d93SSatoshi Sahara return $html; 232f3f0262cSandi} 2330747f5d7Sghi/** 2340747f5d7Sghi * show a revision warning 2350747f5d7Sghi * 2360747f5d7Sghi * @author Szymon Olewniczak <dokuwiki@imz.re> 23787f229e8SSatoshi Sahara * @deprecated 2020-07-18 2380747f5d7Sghi */ 239c8556525Sghifunction html_showrev() { 24079a2d784SGerrit Uitslag dbg_deprecated(PageView::class .'::showrev()'); 2410747f5d7Sghi} 242f3f0262cSandi 243f3f0262cSandi/** 24442ea7f44SGerrit Uitslag * Show a wiki page 24515fae107Sandi * 24615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 24742ea7f44SGerrit Uitslag * 24842ea7f44SGerrit Uitslag * @param null|string $txt wiki text or null for showing $ID 249bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 25015fae107Sandi */ 25111c78c94SAndreas Gohrfunction html_show($txt=null) { 25279a2d784SGerrit Uitslag dbg_deprecated(PageView::class .'::show()'); 253bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\PageView($txt))->show(); 254f3f0262cSandi} 255f3f0262cSandi 256f3f0262cSandi/** 257ee4c4a1bSAndreas Gohr * ask the user about how to handle an exisiting draft 258ee4c4a1bSAndreas Gohr * 259ee4c4a1bSAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 260bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 261ee4c4a1bSAndreas Gohr */ 262ee4c4a1bSAndreas Gohrfunction html_draft() { 26379a2d784SGerrit Uitslag dbg_deprecated(PageDraft::class .'::show()'); 26479a2d784SGerrit Uitslag (new dokuwiki\Ui\PageDraft)->show(); 265ee4c4a1bSAndreas Gohr} 266ee4c4a1bSAndreas Gohr 267ee4c4a1bSAndreas Gohr/** 268f3f0262cSandi * Highlights searchqueries in HTML code 26915fae107Sandi * 27015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 2717209be23SAndreas Gohr * @author Harry Fuecks <hfuecks@gmail.com> 27242ea7f44SGerrit Uitslag * 27342ea7f44SGerrit Uitslag * @param string $html 27442ea7f44SGerrit Uitslag * @param array|string $phrases 27542ea7f44SGerrit Uitslag * @return string html 276f3f0262cSandi */ 277546d3a99SAndreas Gohrfunction html_hilight($html, $phrases) { 2788a803caeSAndreas Gohr $phrases = (array) $phrases; 2798a803caeSAndreas Gohr $phrases = array_map('preg_quote_cb', $phrases); 2808a803caeSAndreas Gohr $phrases = array_map('ft_snippet_re_preprocess', $phrases); 2818a803caeSAndreas Gohr $phrases = array_filter($phrases); 2828a803caeSAndreas Gohr $regex = join('|',$phrases); 28360c15d7dSAndreas Gohr 28460c15d7dSAndreas Gohr if ($regex === '') return $html; 28579a2d784SGerrit Uitslag if (!Clean::isUtf8($regex)) return $html; 286f3f0262cSandi 28779a2d784SGerrit Uitslag return @preg_replace_callback("/((<[^>]*)|$regex)/ui", function ($match) { 288675d8ce4SSatoshi Sahara $hlight = unslash($match[0]); 289675d8ce4SSatoshi Sahara if (!isset($match[2])) { 290688774a0SAnika Henke $hlight = '<span class="search_hit">'.$hlight.'</span>'; 2917209be23SAndreas Gohr } 2927209be23SAndreas Gohr return $hlight; 293675d8ce4SSatoshi Sahara }, $html); 2947209be23SAndreas Gohr} 2957209be23SAndreas Gohr 2967209be23SAndreas Gohr/** 29715fae107Sandi * Display error on locked pages 29815fae107Sandi * 29915fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 3007afe5d93SSatoshi Sahara * @deprecated 2020-07-18 not called anymore, see inc/Action/Locked::tplContent() 30115fae107Sandi */ 302ee20e7d1Sandifunction html_locked() { 30379a2d784SGerrit Uitslag dbg_deprecated(Locked::class .'::showBanner()'); 304a215faf2SSatoshi Sahara (new dokuwiki\Action\Locked())->showBanner(); 305f3f0262cSandi} 306f3f0262cSandi 30715fae107Sandi/** 30815fae107Sandi * list old revisions 30915fae107Sandi * 31015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 31171726d78SBen Coburn * @author Ben Coburn <btcoburn@silicodon.net> 3128e69fd30SKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net> 313e0c26282SGerrit Uitslag * 314e0c26282SGerrit Uitslag * @param int $first skip the first n changelog lines 31530a159abSSatoshi Sahara * @param string $media_id id of media, or empty for current page 316bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 31715fae107Sandi */ 31830a159abSSatoshi Saharafunction html_revisions($first = 0, $media_id = '') { 31979a2d784SGerrit Uitslag dbg_deprecated(PageRevisions::class .'::show()'); 320b370ebcdSSatoshi Sahara if ($media_id) { 321b370ebcdSSatoshi Sahara (new dokuwiki\Ui\MediaRevisions($media_id))->show($first); 322b370ebcdSSatoshi Sahara } else { 323b370ebcdSSatoshi Sahara global $INFO; 324b370ebcdSSatoshi Sahara (new dokuwiki\Ui\PageRevisions($INFO['id']))->show($first); 325b370ebcdSSatoshi Sahara } 326f3f0262cSandi} 327f3f0262cSandi 32815fae107Sandi/** 32915fae107Sandi * display recent changes 33015fae107Sandi * 33115fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 3325749f1ceSmatthiasgrimm * @author Matthias Grimm <matthiasgrimm@users.sourceforge.net> 33371726d78SBen Coburn * @author Ben Coburn <btcoburn@silicodon.net> 3348d40b4b6SKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net> 33542ea7f44SGerrit Uitslag * 33642ea7f44SGerrit Uitslag * @param int $first 33742ea7f44SGerrit Uitslag * @param string $show_changes 338bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 33915fae107Sandi */ 3400739a638SKate Arzamastsevafunction html_recent($first = 0, $show_changes = 'both') { 34179a2d784SGerrit Uitslag dbg_deprecated(Recent::class .'::show()'); 342bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\Recent($first, $show_changes))->show(); 343f3f0262cSandi} 344f3f0262cSandi 34515fae107Sandi/** 34615fae107Sandi * Display page index 34715fae107Sandi * 34815fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 34942ea7f44SGerrit Uitslag * 35042ea7f44SGerrit Uitslag * @param string $ns 351bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 35215fae107Sandi */ 353f3f0262cSandifunction html_index($ns) { 35479a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::show()'); 355bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\Index($ns))->show(); 356f3f0262cSandi} 357f3f0262cSandi 358f3f0262cSandi/** 35989b939d7SSatoshi Sahara * Index tree item formatter for html_buildlist() 36015fae107Sandi * 361f3f0262cSandi * User function for html_buildlist() 36215fae107Sandi * 36315fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 36442ea7f44SGerrit Uitslag * 36542ea7f44SGerrit Uitslag * @param array $item 36642ea7f44SGerrit Uitslag * @return string 3679c8632b4SSatoshi Sahara * @deprecated 2020-07-18 368f3f0262cSandi */ 3699c8632b4SSatoshi Saharafunction html_list_index($item) { 37079a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::formatListItem()'); 3719c8632b4SSatoshi Sahara return (new dokuwiki\Ui\Index)->formatListItem($item); 372f3f0262cSandi} 373f3f0262cSandi 374f3f0262cSandi/** 37589b939d7SSatoshi Sahara * Index list item formatter for html_buildlist() 376cb70c441Sandi * 377a1dee2b9SAdrian Lang * This user function is used in html_buildlist to build the 378cb70c441Sandi * <li> tags for namespaces when displaying the page index 379cb70c441Sandi * it gives different classes to opened or closed "folders" 380cb70c441Sandi * 381cb70c441Sandi * @author Andreas Gohr <andi@splitbrain.org> 38242ea7f44SGerrit Uitslag * 38342ea7f44SGerrit Uitslag * @param array $item 38442ea7f44SGerrit Uitslag * @return string html 3859c8632b4SSatoshi Sahara * @deprecated 2020-07-18 386cb70c441Sandi */ 3879c8632b4SSatoshi Saharafunction html_li_index($item) { 38879a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::tagListItem()'); 3899c8632b4SSatoshi Sahara return (new dokuwiki\Ui\Index)->tagListItem($item); 390cb70c441Sandi} 391cb70c441Sandi 392cb70c441Sandi/** 39389b939d7SSatoshi Sahara * Default list item formatter for html_buildlist() 39489b939d7SSatoshi Sahara * 39589b939d7SSatoshi Sahara * @author Andreas Gohr <andi@splitbrain.org> 39689b939d7SSatoshi Sahara * 39789b939d7SSatoshi Sahara * @param array $item 39889b939d7SSatoshi Sahara * @return string html 39989b939d7SSatoshi Sahara * @deprecated 2020-07-18 40089b939d7SSatoshi Sahara */ 40189b939d7SSatoshi Saharafunction html_li_default($item){ 40289b939d7SSatoshi Sahara return '<li class="level'.$item['level'].'">'; 40389b939d7SSatoshi Sahara} 40489b939d7SSatoshi Sahara 40589b939d7SSatoshi Sahara/** 40615fae107Sandi * Build an unordered list 40715fae107Sandi * 408f3f0262cSandi * Build an unordered list from the given $data array 409f3f0262cSandi * Each item in the array has to have a 'level' property 410f3f0262cSandi * the item itself gets printed by the given $func user 411cb70c441Sandi * function. The second and optional function is used to 412cb70c441Sandi * print the <li> tag. Both user function need to accept 413cb70c441Sandi * a single item. 41415fae107Sandi * 415c5a8fd96SAndreas Gohr * Both user functions can be given as array to point to 416c5a8fd96SAndreas Gohr * a member of an object. 417c5a8fd96SAndreas Gohr * 41815fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 41980679bafSGerrit Uitslag * 42080679bafSGerrit Uitslag * @param array $data array with item arrays 42180679bafSGerrit Uitslag * @param string $class class of ul wrapper 42280679bafSGerrit Uitslag * @param callable $func callback to print an list item 423bde560b4SSatoshi Sahara * @param callable $lifunc (optional) callback to the opening li tag 424bde560b4SSatoshi Sahara * @param bool $forcewrapper (optional) Trigger building a wrapper ul if the first level is 425ae614416SAnika Henke * 0 (we have a root object) or 1 (just the root content) 42680679bafSGerrit Uitslag * @return string html of an unordered list 427f3f0262cSandi */ 428bde560b4SSatoshi Saharafunction html_buildlist($data, $class, $func, $lifunc = null, $forcewrapper = false) { 429a1dee2b9SAdrian Lang if (count($data) === 0) { 430a1dee2b9SAdrian Lang return ''; 431a1dee2b9SAdrian Lang } 432a1dee2b9SAdrian Lang 4332689c55fSMichael Große $firstElement = reset($data); 4342689c55fSMichael Große $start_level = $firstElement['level']; 4359e4f7880SAdrian Lang $level = $start_level; 4369c8632b4SSatoshi Sahara $html = ''; 437434f5921SHakan Sandell $open = 0; 4389e4f7880SAdrian Lang 439bde560b4SSatoshi Sahara // set callback function to build the <li> tag, formerly defined as html_li_default() 440bde560b4SSatoshi Sahara if (!is_callable($lifunc)) { 4419c8632b4SSatoshi Sahara $lifunc = function ($item) { 4429c8632b4SSatoshi Sahara return '<li class="level'.$item['level'].'">'; 4439c8632b4SSatoshi Sahara }; 444bde560b4SSatoshi Sahara } 445bde560b4SSatoshi Sahara 446f3f0262cSandi foreach ($data as $item) { 447f3f0262cSandi if ($item['level'] > $level) { 448f3f0262cSandi //open new list 449df52d0feSandi for ($i = 0; $i < ($item['level'] - $level); $i++) { 4509c8632b4SSatoshi Sahara if ($i) $html .= '<li class="clear">'; 4519c8632b4SSatoshi Sahara $html .= "\n".'<ul class="'.$class.'">'."\n"; 452434f5921SHakan Sandell $open++; 453df52d0feSandi } 454434f5921SHakan Sandell $level = $item['level']; 455434f5921SHakan Sandell 456f3f0262cSandi } elseif ($item['level'] < $level) { 457f3f0262cSandi //close last item 4589c8632b4SSatoshi Sahara $html .= '</li>'."\n"; 459434f5921SHakan Sandell while ($level > $item['level'] && $open > 0 ) { 460f3f0262cSandi //close higher lists 4619c8632b4SSatoshi Sahara $html .= '</ul>'."\n".'</li>'."\n"; 462434f5921SHakan Sandell $level--; 463434f5921SHakan Sandell $open--; 464f3f0262cSandi } 4659c8632b4SSatoshi Sahara } elseif ($html !== '') { 46687671313SHakan Sandell //close previous item 4679c8632b4SSatoshi Sahara $html .= '</li>'."\n"; 468f3f0262cSandi } 469f3f0262cSandi 470f3f0262cSandi //print item 4719c8632b4SSatoshi Sahara $html .= call_user_func($lifunc, $item); 4729c8632b4SSatoshi Sahara $html .= '<div class="li">'; 47334dbe711Schris 4749c8632b4SSatoshi Sahara $html .= call_user_func($func, $item); 4759c8632b4SSatoshi Sahara $html .= '</div>'; 476f3f0262cSandi } 477f3f0262cSandi 478f3f0262cSandi //close remaining items and lists 4799c8632b4SSatoshi Sahara $html .= '</li>'."\n"; 480434f5921SHakan Sandell while ($open-- > 0) { 4819c8632b4SSatoshi Sahara $html .= '</ul></li>'."\n"; 482434f5921SHakan Sandell } 483434f5921SHakan Sandell 484434f5921SHakan Sandell if ($forcewrapper || $start_level < 2) { 485434f5921SHakan Sandell // Trigger building a wrapper ul if the first level is 486434f5921SHakan Sandell // 0 (we have a root object) or 1 (just the root content) 4879c8632b4SSatoshi Sahara $html = "\n".'<ul class="'.$class.'">'."\n".$html.'</ul>'."\n"; 488f3f0262cSandi } 489f3f0262cSandi 4909c8632b4SSatoshi Sahara return $html; 491f3f0262cSandi} 492f3f0262cSandi 49315fae107Sandi/** 49415fae107Sandi * display backlinks 49515fae107Sandi * 49615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 49711df47ecSMichael Klier * @author Michael Klier <chi@chimeric.de> 498bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 49915fae107Sandi */ 500f3f0262cSandifunction html_backlinks() { 50179a2d784SGerrit Uitslag dbg_deprecated(Backlinks::class .'::show()'); 502bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\Backlinks)->show(); 50395b451bcSAdrian Lang} 50495b451bcSAdrian Lang 50515fae107Sandi/** 506a215faf2SSatoshi Sahara * Get header of diff HTML 507a215faf2SSatoshi Sahara * 508a215faf2SSatoshi Sahara * @param string $l_rev Left revisions 509a215faf2SSatoshi Sahara * @param string $r_rev Right revision 510a215faf2SSatoshi Sahara * @param string $id Page id, if null $ID is used 511a215faf2SSatoshi Sahara * @param bool $media If it is for media files 512a215faf2SSatoshi Sahara * @param bool $inline Return the header on a single line 513a215faf2SSatoshi Sahara * @return string[] HTML snippets for diff header 514a215faf2SSatoshi Sahara * @deprecated 2020-07-18 515a215faf2SSatoshi Sahara */ 516a215faf2SSatoshi Saharafunction html_diff_head($l_rev, $r_rev, $id = null, $media = false, $inline = false) { 51779a2d784SGerrit Uitslag dbg_deprecated('see '. PageDiff::class .'::buildDiffHead()'); 51879a2d784SGerrit Uitslag return ['', '', '', '']; 519a215faf2SSatoshi Sahara} 520a215faf2SSatoshi Sahara 521a215faf2SSatoshi Sahara/** 52204e99fe1SGerrit Uitslag * Show diff 523baf0c3e5SGerrit Uitslag * between current page version and provided $text 524baf0c3e5SGerrit Uitslag * or between the revisions provided via GET or POST 52515fae107Sandi * 52615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 527baf0c3e5SGerrit Uitslag * @param string $text when non-empty: compare with this text with most current version 52804e99fe1SGerrit Uitslag * @param bool $intro display the intro text 5298d5e837eSMichael Hamann * @param string $type type of the diff (inline or sidebyside) 530bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 53115fae107Sandi */ 53272165381SAndreas Gohrfunction html_diff($text = '', $intro = true, $type = null) { 53379a2d784SGerrit Uitslag dbg_deprecated(PageDiff::class .'::show()'); 534edb50e6aSSatoshi Sahara global $INFO; 535e4c881bdSSatoshi Sahara (new dokuwiki\Ui\PageDiff($INFO['id']))->compareWith($text)->preference([ 536edb50e6aSSatoshi Sahara 'showIntro' => $intro, 537edb50e6aSSatoshi Sahara 'difftype' => $type, 538edb50e6aSSatoshi Sahara ])->show(); 539fcfecb69SChristopher Smith} 540fcfecb69SChristopher Smith 54115fae107Sandi/** 542a215faf2SSatoshi Sahara * Create html for revision navigation 543a215faf2SSatoshi Sahara * 544a215faf2SSatoshi Sahara * @param PageChangeLog $pagelog changelog object of current page 545a215faf2SSatoshi Sahara * @param string $type inline vs sidebyside 546a215faf2SSatoshi Sahara * @param int $l_rev left revision timestamp 547a215faf2SSatoshi Sahara * @param int $r_rev right revision timestamp 548a215faf2SSatoshi Sahara * @return string[] html of left and right navigation elements 549a215faf2SSatoshi Sahara * @deprecated 2020-07-18 550a215faf2SSatoshi Sahara */ 551a215faf2SSatoshi Saharafunction html_diff_navigation($pagelog, $type, $l_rev, $r_rev) { 55279a2d784SGerrit Uitslag dbg_deprecated('see '. PageDiff::class .'::buildRevisionsNavigation()'); 55379a2d784SGerrit Uitslag return ['', '']; 554a215faf2SSatoshi Sahara} 555a215faf2SSatoshi Sahara 556a215faf2SSatoshi Sahara/** 557a215faf2SSatoshi Sahara * Create html link to a diff defined by two revisions 558a215faf2SSatoshi Sahara * 559a215faf2SSatoshi Sahara * @param string $difftype display type 560a215faf2SSatoshi Sahara * @param string $linktype 561a215faf2SSatoshi Sahara * @param int $lrev oldest revision 562a215faf2SSatoshi Sahara * @param int $rrev newest revision or null for diff with current revision 563a215faf2SSatoshi Sahara * @return string html of link to a diff 564a215faf2SSatoshi Sahara * @deprecated 2020-07-18 565a215faf2SSatoshi Sahara */ 566a215faf2SSatoshi Saharafunction html_diff_navigationlink($difftype, $linktype, $lrev, $rrev = null) { 56779a2d784SGerrit Uitslag dbg_deprecated('see '. PageDiff::class .'::diffViewlink()'); 56879a2d784SGerrit Uitslag return ''; 569a215faf2SSatoshi Sahara} 570a215faf2SSatoshi Sahara 571a215faf2SSatoshi Sahara/** 572a215faf2SSatoshi Sahara * Insert soft breaks in diff html 573a215faf2SSatoshi Sahara * 574a215faf2SSatoshi Sahara * @param string $diffhtml 575a215faf2SSatoshi Sahara * @return string 576a215faf2SSatoshi Sahara * @deprecated 2020-07-18 577a215faf2SSatoshi Sahara */ 578a215faf2SSatoshi Saharafunction html_insert_softbreaks($diffhtml) { 57979a2d784SGerrit Uitslag dbg_deprecated(PageDiff::class .'::insertSoftbreaks()'); 58087922387SSatoshi Sahara return (new dokuwiki\Ui\PageDiff)->insertSoftbreaks($diffhtml); 581a215faf2SSatoshi Sahara} 582a215faf2SSatoshi Sahara 583a215faf2SSatoshi Sahara/** 58415fae107Sandi * show warning on conflict detection 58515fae107Sandi * 58615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 58742ea7f44SGerrit Uitslag * 58842ea7f44SGerrit Uitslag * @param string $text 58942ea7f44SGerrit Uitslag * @param string $summary 590bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 59115fae107Sandi */ 592f3f0262cSandifunction html_conflict($text, $summary) { 59379a2d784SGerrit Uitslag dbg_deprecated(PageConflict::class .'::show()'); 594edb50e6aSSatoshi Sahara (new dokuwiki\Ui\PageConflict($text, $summary))->show(); 595f3f0262cSandi} 596f3f0262cSandi 597f3f0262cSandi/** 59815fae107Sandi * Prints the global message array 59915fae107Sandi * 60015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 601f3f0262cSandi */ 602f3f0262cSandifunction html_msgarea() { 603cc58224cSMichael Hamann global $MSG, $MSG_shown; 6048d5e837eSMichael Hamann /** @var array $MSG */ 605cc58224cSMichael Hamann // store if the global $MSG has already been shown and thus HTML output has been started 606cc58224cSMichael Hamann $MSG_shown = true; 607cc58224cSMichael Hamann 608f3f0262cSandi if (!isset($MSG)) return; 609f3f0262cSandi 6104af9f0d4SAndreas Gohr $shown = array(); 611f3f0262cSandi foreach ($MSG as $msg) { 6124af9f0d4SAndreas Gohr $hash = md5($msg['msg']); 6134af9f0d4SAndreas Gohr if (isset($shown[$hash])) continue; // skip double messages 614f755f9abSChristopher Smith if (info_msg_allowed($msg)) { 615f3f0262cSandi print '<div class="'.$msg['lvl'].'">'; 616f3f0262cSandi print $msg['msg']; 617f3f0262cSandi print '</div>'; 618d3bae478SChristopher Smith } 6194af9f0d4SAndreas Gohr $shown[$hash] = 1; 620f3f0262cSandi } 621cc58224cSMichael Hamann 622cc58224cSMichael Hamann unset($GLOBALS['MSG']); 623f3f0262cSandi} 624f3f0262cSandi 625f3f0262cSandi/** 626f3f0262cSandi * Prints the registration form 62715fae107Sandi * 62815fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 629bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 630f3f0262cSandi */ 631f3f0262cSandifunction html_register() { 63279a2d784SGerrit Uitslag dbg_deprecated(UserRegister::class .'::show()'); 633bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\UserRegister)->show(); 634f3f0262cSandi} 635f3f0262cSandi 636f3f0262cSandi/** 6378b06d178Schris * Print the update profile form 6388b06d178Schris * 6398b06d178Schris * @author Christopher Smith <chris@jalakai.co.uk> 6408b06d178Schris * @author Andreas Gohr <andi@splitbrain.org> 641bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 6428b06d178Schris */ 6438b06d178Schrisfunction html_updateprofile() { 64479a2d784SGerrit Uitslag dbg_deprecated(UserProfile::class .'::show()'); 645bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\UserProfile)->show(); 6468b06d178Schris} 6478b06d178Schris 6488b06d178Schris/** 6497c4635c4SAdrian Lang * Preprocess edit form data 65015fae107Sandi * 65115fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 6522ffea8f2SAdrian Lang * 653bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 654f3f0262cSandi */ 6555a932e77SAdrian Langfunction html_edit() { 65679a2d784SGerrit Uitslag dbg_deprecated(Editor::class .'::show()'); 657bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\Editor)->show(); 658b6912aeaSAndreas Gohr} 659b6912aeaSAndreas Gohr 660b6912aeaSAndreas Gohr/** 661bf69f8cbSSatoshi Sahara * Display the default edit form 662bf69f8cbSSatoshi Sahara * 663bf69f8cbSSatoshi Sahara * Is the default action for HTML_EDIT_FORMSELECTION. 664bf69f8cbSSatoshi Sahara * 66579a2d784SGerrit Uitslag * @param array $param 666bf69f8cbSSatoshi Sahara * @deprecated 2020-07-18 667bf69f8cbSSatoshi Sahara */ 668bf69f8cbSSatoshi Saharafunction html_edit_form($param) { 66979a2d784SGerrit Uitslag dbg_deprecated(Editor::class .'::addTextarea()'); 67079a2d784SGerrit Uitslag (new dokuwiki\Ui\Editor)->addTextarea($param); 671bf69f8cbSSatoshi Sahara} 672bf69f8cbSSatoshi Sahara 673bf69f8cbSSatoshi Sahara/** 674f3f0262cSandi * prints some debug info 67515fae107Sandi * 67615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 677f3f0262cSandi */ 678f3f0262cSandifunction html_debug() { 679f3f0262cSandi global $conf; 680d16a4edaSandi global $lang; 681e1d9dcc8SAndreas Gohr /** @var AuthPlugin $auth */ 6825298a619SAndreas Gohr global $auth; 683100a97e3SAndreas Gohr global $INFO; 684100a97e3SAndreas Gohr 68528fb55ffSandi //remove sensitive data 68628fb55ffSandi $cnf = $conf; 68724297a69SAndreas Gohr debug_guard($cnf); 688100a97e3SAndreas Gohr $nfo = $INFO; 68924297a69SAndreas Gohr debug_guard($nfo); 690100a97e3SAndreas Gohr $ses = $_SESSION; 69124297a69SAndreas Gohr debug_guard($ses); 692f3f0262cSandi 693f3f0262cSandi print '<html><body>'; 694f3f0262cSandi 695f3f0262cSandi print '<p>When reporting bugs please send all the following '; 696f3f0262cSandi print 'output as a mail to andi@splitbrain.org '; 697f3f0262cSandi print 'The best way to do this is to save this page in your browser</p>'; 698f3f0262cSandi 699100a97e3SAndreas Gohr print '<b>$INFO:</b><pre>'; 700100a97e3SAndreas Gohr print_r($nfo); 701100a97e3SAndreas Gohr print '</pre>'; 702100a97e3SAndreas Gohr 703f3f0262cSandi print '<b>$_SERVER:</b><pre>'; 704f3f0262cSandi print_r($_SERVER); 705f3f0262cSandi print '</pre>'; 706f3f0262cSandi 707f3f0262cSandi print '<b>$conf:</b><pre>'; 70828fb55ffSandi print_r($cnf); 709f3f0262cSandi print '</pre>'; 710f3f0262cSandi 711ed7b5f09Sandi print '<b>DOKU_BASE:</b><pre>'; 712ed7b5f09Sandi print DOKU_BASE; 713f3f0262cSandi print '</pre>'; 714f3f0262cSandi 715ed7b5f09Sandi print '<b>abs DOKU_BASE:</b><pre>'; 716ed7b5f09Sandi print DOKU_URL; 717ed7b5f09Sandi print '</pre>'; 718ed7b5f09Sandi 719ed7b5f09Sandi print '<b>rel DOKU_BASE:</b><pre>'; 720f3f0262cSandi print dirname($_SERVER['PHP_SELF']).'/'; 721f3f0262cSandi print '</pre>'; 722f3f0262cSandi 723f3f0262cSandi print '<b>PHP Version:</b><pre>'; 724f3f0262cSandi print phpversion(); 725f3f0262cSandi print '</pre>'; 726f3f0262cSandi 727f3f0262cSandi print '<b>locale:</b><pre>'; 728f3f0262cSandi print setlocale(LC_ALL,0); 729f3f0262cSandi print '</pre>'; 730f3f0262cSandi 731d16a4edaSandi print '<b>encoding:</b><pre>'; 732d16a4edaSandi print $lang['encoding']; 733d16a4edaSandi print '</pre>'; 734d16a4edaSandi 7355298a619SAndreas Gohr if ($auth) { 7365298a619SAndreas Gohr print '<b>Auth backend capabilities:</b><pre>'; 7372f46ade0SChristopher Smith foreach ($auth->getCapabilities() as $cando) { 7387afe5d93SSatoshi Sahara print ' '.str_pad($cando,16) .' => '. (int)$auth->canDo($cando) . DOKU_LF; 7392f46ade0SChristopher Smith } 7405298a619SAndreas Gohr print '</pre>'; 7415298a619SAndreas Gohr } 7425298a619SAndreas Gohr 7433aa54d7cSAndreas Gohr print '<b>$_SESSION:</b><pre>'; 744100a97e3SAndreas Gohr print_r($ses); 7453aa54d7cSAndreas Gohr print '</pre>'; 7463aa54d7cSAndreas Gohr 747f3f0262cSandi print '<b>Environment:</b><pre>'; 748f3f0262cSandi print_r($_ENV); 749f3f0262cSandi print '</pre>'; 750f3f0262cSandi 751f3f0262cSandi print '<b>PHP settings:</b><pre>'; 752f3f0262cSandi $inis = ini_get_all(); 753f3f0262cSandi print_r($inis); 754f3f0262cSandi print '</pre>'; 755f3f0262cSandi 756e89b7c1eSChristopher Smith if (function_exists('apache_get_version')) { 75759bc3b48SGerrit Uitslag $apache = array(); 758e89b7c1eSChristopher Smith $apache['version'] = apache_get_version(); 759e89b7c1eSChristopher Smith 760e89b7c1eSChristopher Smith if (function_exists('apache_get_modules')) { 761e89b7c1eSChristopher Smith $apache['modules'] = apache_get_modules(); 762e89b7c1eSChristopher Smith } 763e89b7c1eSChristopher Smith print '<b>Apache</b><pre>'; 764e89b7c1eSChristopher Smith print_r($apache); 765e89b7c1eSChristopher Smith print '</pre>'; 766e89b7c1eSChristopher Smith } 767e89b7c1eSChristopher Smith 768f3f0262cSandi print '</body></html>'; 769f3f0262cSandi} 770f3f0262cSandi 77110271ce4SAndreas Gohr/** 7728b06d178Schris * Form to request a new password for an existing account 7738b06d178Schris * 7748b06d178Schris * @author Benoit Chesneau <benoit@bchesneau.info> 775cc204bbdSAndreas Gohr * @author Andreas Gohr <gohr@cosmocode.de> 776bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 77711e2ce22Schris */ 7788b06d178Schrisfunction html_resendpwd() { 77979a2d784SGerrit Uitslag dbg_deprecated(UserResendPwd::class .'::show()'); 780bab2b7f0SSatoshi Sahara (new dokuwiki\Ui\UserResendPwd)->show(); 781cc204bbdSAndreas Gohr} 782cc204bbdSAndreas Gohr 783fdb8d77bSTom N Harris/** 784b8595a66SAndreas Gohr * Return the TOC rendered to XHTML 785b8595a66SAndreas Gohr * 786b8595a66SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 78742ea7f44SGerrit Uitslag * 78842ea7f44SGerrit Uitslag * @param array $toc 78942ea7f44SGerrit Uitslag * @return string html 790b8595a66SAndreas Gohr */ 791b8595a66SAndreas Gohrfunction html_TOC($toc) { 792b8595a66SAndreas Gohr if (!count($toc)) return ''; 793b8595a66SAndreas Gohr global $lang; 794b8595a66SAndreas Gohr $out = '<!-- TOC START -->'.DOKU_LF; 795158a5bffSDeathCamel57 $out .= '<div id="dw__toc" class="dw__toc">'.DOKU_LF; 79648722ac8SAnika Henke $out .= '<h3 class="toggle">'; 797b8595a66SAndreas Gohr $out .= $lang['toc']; 798d5acc30dSAnika Henke $out .= '</h3>'.DOKU_LF; 799d5acc30dSAnika Henke $out .= '<div>'.DOKU_LF; 800bde560b4SSatoshi Sahara $out .= html_buildlist($toc, 'toc', 'html_list_toc', null, true); 801b8595a66SAndreas Gohr $out .= '</div>'.DOKU_LF.'</div>'.DOKU_LF; 802b8595a66SAndreas Gohr $out .= '<!-- TOC END -->'.DOKU_LF; 803db959ae3SAndreas Gohr return $out; 804db959ae3SAndreas Gohr} 805b8595a66SAndreas Gohr 806b8595a66SAndreas Gohr/** 807b8595a66SAndreas Gohr * Callback for html_buildlist 80842ea7f44SGerrit Uitslag * 80942ea7f44SGerrit Uitslag * @param array $item 81042ea7f44SGerrit Uitslag * @return string html 811b8595a66SAndreas Gohr */ 812b8595a66SAndreas Gohrfunction html_list_toc($item) { 813c66972f2SAdrian Lang if (isset($item['hid'])){ 8147d91652aSAndreas Gohr $link = '#'.$item['hid']; 8157d91652aSAndreas Gohr } else { 8167d91652aSAndreas Gohr $link = $item['link']; 8177d91652aSAndreas Gohr } 8187d91652aSAndreas Gohr 819d5acc30dSAnika Henke return '<a href="'.$link.'">'.hsc($item['title']).'</a>'; 820b8595a66SAndreas Gohr} 821b8595a66SAndreas Gohr 822b8595a66SAndreas Gohr/** 823b8595a66SAndreas Gohr * Helper function to build TOC items 824b8595a66SAndreas Gohr * 825b8595a66SAndreas Gohr * Returns an array ready to be added to a TOC array 826b8595a66SAndreas Gohr * 827b8595a66SAndreas Gohr * @param string $link - where to link (if $hash set to '#' it's a local anchor) 828b8595a66SAndreas Gohr * @param string $text - what to display in the TOC 829b8595a66SAndreas Gohr * @param int $level - nesting level 830b8595a66SAndreas Gohr * @param string $hash - is prepended to the given $link, set blank if you want full links 8318d5e837eSMichael Hamann * @return array the toc item 832b8595a66SAndreas Gohr */ 833b8595a66SAndreas Gohrfunction html_mktocitem($link, $text, $level, $hash='#') { 834bde560b4SSatoshi Sahara return array( 835bde560b4SSatoshi Sahara 'link' => $hash.$link, 836b8595a66SAndreas Gohr 'title' => $text, 837b8595a66SAndreas Gohr 'type' => 'ul', 838bde560b4SSatoshi Sahara 'level' => $level 839bde560b4SSatoshi Sahara ); 840b8595a66SAndreas Gohr} 841b8595a66SAndreas Gohr 842b8595a66SAndreas Gohr/** 843fdb8d77bSTom N Harris * Output a Doku_Form object. 844fdb8d77bSTom N Harris * Triggers an event with the form name: HTML_{$name}FORM_OUTPUT 845fdb8d77bSTom N Harris * 846fdb8d77bSTom N Harris * @author Tom N Harris <tnharris@whoopdedo.org> 84742ea7f44SGerrit Uitslag * 8488d5e837eSMichael Hamann * @param string $name The name of the form 8498d5e837eSMichael Hamann * @param Doku_Form $form The form 8502162df3aSSatoshi Sahara * @return void 8512162df3aSSatoshi Sahara * @deprecated 2020-07-18 852fdb8d77bSTom N Harris */ 853c29600d0SSatoshi Saharafunction html_form($name, $form) { 8548a5f08afSSatoshi Sahara dbg_deprecated('use dokuwiki\Form\Form instead of Doku_Form'); 855fdb8d77bSTom N Harris // Safety check in case the caller forgets. 856fdb8d77bSTom N Harris $form->endFieldset(); 857cbb44eabSAndreas Gohr Event::createAndTrigger('HTML_'.strtoupper($name).'FORM_OUTPUT', $form, 'html_form_output', false); 858fdb8d77bSTom N Harris} 859fdb8d77bSTom N Harris 860fdb8d77bSTom N Harris/** 861fdb8d77bSTom N Harris * Form print function. 862c29600d0SSatoshi Sahara * Just calls printForm() on the form object. 86342ea7f44SGerrit Uitslag * 864c29600d0SSatoshi Sahara * @param Doku_Form $form The form 8652162df3aSSatoshi Sahara * @return void 8662162df3aSSatoshi Sahara * @deprecated 2020-07-18 867fdb8d77bSTom N Harris */ 86825dd2a2fSSatoshi Saharafunction html_form_output($form) { 8698a5f08afSSatoshi Sahara dbg_deprecated('use dokuwiki\Form\Form::toHTML()'); 87025dd2a2fSSatoshi Sahara $form->printForm(); 87125dd2a2fSSatoshi Sahara} 872340756e4Sandi 87307bf32b2SAndreas Gohr/** 87407bf32b2SAndreas Gohr * Embed a flash object in HTML 87507bf32b2SAndreas Gohr * 87607bf32b2SAndreas Gohr * This will create the needed HTML to embed a flash movie in a cross browser 87707bf32b2SAndreas Gohr * compatble way using valid XHTML 87807bf32b2SAndreas Gohr * 87907bf32b2SAndreas Gohr * The parameters $params, $flashvars and $atts need to be associative arrays. 88007bf32b2SAndreas Gohr * No escaping needs to be done for them. The alternative content *has* to be 88107bf32b2SAndreas Gohr * escaped because it is used as is. If no alternative content is given 88207bf32b2SAndreas Gohr * $lang['noflash'] is used. 88307bf32b2SAndreas Gohr * 88407bf32b2SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 88507bf32b2SAndreas Gohr * @link http://latrine.dgx.cz/how-to-correctly-insert-a-flash-into-xhtml 88607bf32b2SAndreas Gohr * 88707bf32b2SAndreas Gohr * @param string $swf - the SWF movie to embed 88807bf32b2SAndreas Gohr * @param int $width - width of the flash movie in pixels 88907bf32b2SAndreas Gohr * @param int $height - height of the flash movie in pixels 89007bf32b2SAndreas Gohr * @param array $params - additional parameters (<param>) 89107bf32b2SAndreas Gohr * @param array $flashvars - parameters to be passed in the flashvar parameter 89207bf32b2SAndreas Gohr * @param array $atts - additional attributes for the <object> tag 89307bf32b2SAndreas Gohr * @param string $alt - alternative content (is NOT automatically escaped!) 894b3d1090eSMichael Hamann * @return string - the XHTML markup 89507bf32b2SAndreas Gohr */ 89607bf32b2SAndreas Gohrfunction html_flashobject($swf,$width,$height,$params=null,$flashvars=null,$atts=null,$alt=''){ 89707bf32b2SAndreas Gohr global $lang; 89807bf32b2SAndreas Gohr 89907bf32b2SAndreas Gohr $out = ''; 90007bf32b2SAndreas Gohr 90107bf32b2SAndreas Gohr // prepare the object attributes 90207bf32b2SAndreas Gohr if(is_null($atts)) $atts = array(); 90307bf32b2SAndreas Gohr $atts['width'] = (int) $width; 904d4c61e61SAndreas Gohr $atts['height'] = (int) $height; 90507bf32b2SAndreas Gohr if(!$atts['width']) $atts['width'] = 425; 90607bf32b2SAndreas Gohr if(!$atts['height']) $atts['height'] = 350; 90707bf32b2SAndreas Gohr 90807bf32b2SAndreas Gohr // add object attributes for standard compliant browsers 90907bf32b2SAndreas Gohr $std = $atts; 91007bf32b2SAndreas Gohr $std['type'] = 'application/x-shockwave-flash'; 91107bf32b2SAndreas Gohr $std['data'] = $swf; 91207bf32b2SAndreas Gohr 91307bf32b2SAndreas Gohr // add object attributes for IE 91407bf32b2SAndreas Gohr $ie = $atts; 91507bf32b2SAndreas Gohr $ie['classid'] = 'clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'; 91607bf32b2SAndreas Gohr 91707bf32b2SAndreas Gohr // open object (with conditional comments) 91807bf32b2SAndreas Gohr $out .= '<!--[if !IE]> -->'.NL; 91907bf32b2SAndreas Gohr $out .= '<object '.buildAttributes($std).'>'.NL; 92007bf32b2SAndreas Gohr $out .= '<!-- <![endif]-->'.NL; 92107bf32b2SAndreas Gohr $out .= '<!--[if IE]>'.NL; 92207bf32b2SAndreas Gohr $out .= '<object '.buildAttributes($ie).'>'.NL; 92307bf32b2SAndreas Gohr $out .= ' <param name="movie" value="'.hsc($swf).'" />'.NL; 9249ae41cdcSAndreas Gohr $out .= '<!--><!-- -->'.NL; 92507bf32b2SAndreas Gohr 92607bf32b2SAndreas Gohr // print params 92707bf32b2SAndreas Gohr if(is_array($params)) foreach($params as $key => $val){ 92807bf32b2SAndreas Gohr $out .= ' <param name="'.hsc($key).'" value="'.hsc($val).'" />'.NL; 92907bf32b2SAndreas Gohr } 93007bf32b2SAndreas Gohr 93107bf32b2SAndreas Gohr // add flashvars 93207bf32b2SAndreas Gohr if(is_array($flashvars)){ 933d4c61e61SAndreas Gohr $out .= ' <param name="FlashVars" value="'.buildURLparams($flashvars).'" />'.NL; 93407bf32b2SAndreas Gohr } 93507bf32b2SAndreas Gohr 93607bf32b2SAndreas Gohr // alternative content 93707bf32b2SAndreas Gohr if($alt){ 93807bf32b2SAndreas Gohr $out .= $alt.NL; 93907bf32b2SAndreas Gohr }else{ 94007bf32b2SAndreas Gohr $out .= $lang['noflash'].NL; 94107bf32b2SAndreas Gohr } 94207bf32b2SAndreas Gohr 94307bf32b2SAndreas Gohr // finish 94407bf32b2SAndreas Gohr $out .= '</object>'.NL; 94507bf32b2SAndreas Gohr $out .= '<!-- <![endif]-->'.NL; 94607bf32b2SAndreas Gohr 94707bf32b2SAndreas Gohr return $out; 94807bf32b2SAndreas Gohr} 94907bf32b2SAndreas Gohr 9508d5e837eSMichael Hamann/** 9518d5e837eSMichael Hamann * Prints HTML code for the given tab structure 9528d5e837eSMichael Hamann * 9538d5e837eSMichael Hamann * @param array $tabs tab structure 9548d5e837eSMichael Hamann * @param string $current_tab the current tab id 9552162df3aSSatoshi Sahara * @return void 9568d5e837eSMichael Hamann */ 95795b451bcSAdrian Langfunction html_tabs($tabs, $current_tab = null) { 95894add303SAnika Henke echo '<ul class="tabs">'.NL; 95995b451bcSAdrian Lang 96095b451bcSAdrian Lang foreach ($tabs as $id => $tab) { 96195b451bcSAdrian Lang html_tab($tab['href'], $tab['caption'], $id === $current_tab); 96295b451bcSAdrian Lang } 96395b451bcSAdrian Lang 96494add303SAnika Henke echo '</ul>'.NL; 96595b451bcSAdrian Lang} 966cd2a4cfdSAnika Henke 96795b451bcSAdrian Lang/** 96895b451bcSAdrian Lang * Prints a single tab 96995b451bcSAdrian Lang * 97095b451bcSAdrian Lang * @author Kate Arzamastseva <pshns@ukr.net> 97195b451bcSAdrian Lang * @author Adrian Lang <mail@adrianlang.de> 97295b451bcSAdrian Lang * 97395b451bcSAdrian Lang * @param string $href - tab href 97495b451bcSAdrian Lang * @param string $caption - tab caption 97595b451bcSAdrian Lang * @param boolean $selected - is tab selected 9762162df3aSSatoshi Sahara * @return void 97795b451bcSAdrian Lang */ 97895b451bcSAdrian Lang 97995b451bcSAdrian Langfunction html_tab($href, $caption, $selected = false) { 98095b451bcSAdrian Lang $tab = '<li>'; 98195b451bcSAdrian Lang if ($selected) { 98295b451bcSAdrian Lang $tab .= '<strong>'; 98395b451bcSAdrian Lang } else { 98495b451bcSAdrian Lang $tab .= '<a href="' . hsc($href) . '">'; 98595b451bcSAdrian Lang } 98695b451bcSAdrian Lang $tab .= hsc($caption) 98795b451bcSAdrian Lang . '</' . ($selected ? 'strong' : 'a') . '>' 98894add303SAnika Henke . '</li>'.NL; 98995b451bcSAdrian Lang echo $tab; 99095b451bcSAdrian Lang} 99195b451bcSAdrian Lang 992cd2a4cfdSAnika Henke/** 993cd2a4cfdSAnika Henke * Display size change 994cd2a4cfdSAnika Henke * 995cd2a4cfdSAnika Henke * @param int $sizechange - size of change in Bytes 996e34d6962SSatoshi Sahara * @param Doku_Form $form - (optional) form to add elements to 997e34d6962SSatoshi Sahara * @return void|string 998cd2a4cfdSAnika Henke */ 999e34d6962SSatoshi Saharafunction html_sizechange($sizechange, $form = null) { 1000cd2a4cfdSAnika Henke if (isset($sizechange)) { 1001cd2a4cfdSAnika Henke $class = 'sizechange'; 1002cd2a4cfdSAnika Henke $value = filesize_h(abs($sizechange)); 1003cd2a4cfdSAnika Henke if ($sizechange > 0) { 1004cd2a4cfdSAnika Henke $class .= ' positive'; 1005cd2a4cfdSAnika Henke $value = '+' . $value; 1006cd2a4cfdSAnika Henke } elseif ($sizechange < 0) { 1007cd2a4cfdSAnika Henke $class .= ' negative'; 1008cd2a4cfdSAnika Henke $value = '-' . $value; 10090b78a6edSAnika Henke } else { 10100b78a6edSAnika Henke $value = '±' . $value; 1011cd2a4cfdSAnika Henke } 1012e34d6962SSatoshi Sahara if (!isset($form)) { 1013e34d6962SSatoshi Sahara return '<span class="'.$class.'">'.$value.'</span>'; 1014b0f23f4eSSatoshi Sahara } else { // Doku_Form 1015cd2a4cfdSAnika Henke $form->addElement(form_makeOpenTag('span', array('class' => $class))); 1016cd2a4cfdSAnika Henke $form->addElement($value); 1017cd2a4cfdSAnika Henke $form->addElement(form_makeCloseTag('span')); 1018cd2a4cfdSAnika Henke } 1019cd2a4cfdSAnika Henke } 1020b0f23f4eSSatoshi Sahara} 1021