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 */ 8*24870174SAndreas Gohruse dokuwiki\Ui\MediaRevisions; 9*24870174SAndreas Gohruse dokuwiki\Form\Form; 1079a2d784SGerrit Uitslaguse dokuwiki\Action\Denied; 1179a2d784SGerrit Uitslaguse dokuwiki\Action\Locked; 120c3a5702SAndreas Gohruse dokuwiki\ChangeLog\PageChangeLog; 13e1d9dcc8SAndreas Gohruse dokuwiki\Extension\AuthPlugin; 14cbb44eabSAndreas Gohruse dokuwiki\Extension\Event; 1579a2d784SGerrit Uitslaguse dokuwiki\Ui\Backlinks; 1679a2d784SGerrit Uitslaguse dokuwiki\Ui\Editor; 1779a2d784SGerrit Uitslaguse dokuwiki\Ui\Index; 1879a2d784SGerrit Uitslaguse dokuwiki\Ui\Login; 1979a2d784SGerrit Uitslaguse dokuwiki\Ui\PageConflict; 2079a2d784SGerrit Uitslaguse dokuwiki\Ui\PageDiff; 2179a2d784SGerrit Uitslaguse dokuwiki\Ui\PageDraft; 2279a2d784SGerrit Uitslaguse dokuwiki\Ui\PageRevisions; 2379a2d784SGerrit Uitslaguse dokuwiki\Ui\PageView; 2479a2d784SGerrit Uitslaguse dokuwiki\Ui\Recent; 2579a2d784SGerrit Uitslaguse dokuwiki\Ui\UserProfile; 2679a2d784SGerrit Uitslaguse dokuwiki\Ui\UserRegister; 2779a2d784SGerrit Uitslaguse dokuwiki\Ui\UserResendPwd; 2879a2d784SGerrit Uitslaguse dokuwiki\Utf8\Clean; 290c3a5702SAndreas Gohr 302d3b082eSMichael Großeif (!defined('SEC_EDIT_PATTERN')) { 3137c80e0eSLarsDW223 define('SEC_EDIT_PATTERN', '#<!-- EDIT({.*?}) -->#'); 322d3b082eSMichael Große} 332d3b082eSMichael Große 346bbae538Sandi 35f3f0262cSandi/** 36f3f0262cSandi * Convenience function to quickly build a wikilink 3715fae107Sandi * 3815fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 398d5e837eSMichael Hamann * @param string $id id of the target page 408d5e837eSMichael Hamann * @param string $name the name of the link, i.e. the text that is displayed 418d5e837eSMichael Hamann * @param string|array $search search string(s) that shall be highlighted in the target page 428d5e837eSMichael Hamann * @return string the HTML code of the link 43f3f0262cSandi */ 44db959ae3SAndreas Gohrfunction html_wikilink($id, $name = null, $search = '') { 45a8397511SGerrit Uitslag /** @var Doku_Renderer_xhtml $xhtml_renderer */ 46db959ae3SAndreas Gohr static $xhtml_renderer = null; 47723d78dbSandi if (is_null($xhtml_renderer)) { 487aea91afSChris Smith $xhtml_renderer = p_get_renderer('xhtml'); 49f3f0262cSandi } 50f3f0262cSandi 51fe9ec250SChris Smith return $xhtml_renderer->internallink($id,$name,$search,true,'navigation'); 52f3f0262cSandi} 53f3f0262cSandi 54f3f0262cSandi/** 55f3f0262cSandi * The loginform 5615fae107Sandi * 5715fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 58d1d904bbSMichael Große * 59d1d904bbSMichael Große * @param bool $svg Whether to show svg icons in the register and resendpwd links or not 60bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 61f3f0262cSandi */ 62d1d904bbSMichael Großefunction html_login($svg = false) { 6379a2d784SGerrit Uitslag dbg_deprecated(Login::class .'::show()'); 64*24870174SAndreas Gohr (new Login($svg))->show(); 65f3f0262cSandi} 66f3f0262cSandi 67d59dea9fSGerrit Uitslag 68d59dea9fSGerrit Uitslag/** 69d59dea9fSGerrit Uitslag * Denied page content 70d59dea9fSGerrit Uitslag * 717afe5d93SSatoshi Sahara * @deprecated 2020-07-18 not called anymore, see inc/Action/Denied::tplContent() 72d59dea9fSGerrit Uitslag */ 73d59dea9fSGerrit Uitslagfunction html_denied() { 7479a2d784SGerrit Uitslag dbg_deprecated(Denied::class .'::showBanner()'); 75*24870174SAndreas Gohr (new Denied())->showBanner(); 76d59dea9fSGerrit Uitslag} 77d59dea9fSGerrit Uitslag 78f3f0262cSandi/** 7915fae107Sandi * inserts section edit buttons if wanted or removes the markers 8015fae107Sandi * 8115fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 8242ea7f44SGerrit Uitslag * 8342ea7f44SGerrit Uitslag * @param string $text 8442ea7f44SGerrit Uitslag * @param bool $show show section edit buttons? 8542ea7f44SGerrit Uitslag * @return string 8615fae107Sandi */ 87f3f0262cSandifunction html_secedit($text, $show = true) { 88f3f0262cSandi global $INFO; 8935dae8b0SBen Coburn 90aac83cd4SPhy if ((isset($INFO) && !$INFO['writable']) || !$show || (isset($INFO) && $INFO['rev'])) { 912d3b082eSMichael Große return preg_replace(SEC_EDIT_PATTERN,'',$text); 92f3f0262cSandi } 9335dae8b0SBen Coburn 942d3b082eSMichael Große return preg_replace_callback(SEC_EDIT_PATTERN, 9540868f2fSAdrian Lang 'html_secedit_button', $text); 9640868f2fSAdrian Lang} 9740868f2fSAdrian Lang 9840868f2fSAdrian Lang/** 9940868f2fSAdrian Lang * prepares section edit button data for event triggering 10040868f2fSAdrian Lang * used as a callback in html_secedit 10140868f2fSAdrian Lang * 10240868f2fSAdrian Lang * @author Andreas Gohr <andi@splitbrain.org> 10342ea7f44SGerrit Uitslag * 10442ea7f44SGerrit Uitslag * @param array $matches matches with regexp 10542ea7f44SGerrit Uitslag * @return string 10642ea7f44SGerrit Uitslag * @triggers HTML_SECEDIT_BUTTON 10740868f2fSAdrian Lang */ 10840868f2fSAdrian Langfunction html_secedit_button($matches){ 109ada0d779SMichael Hamann $json = htmlspecialchars_decode($matches[1], ENT_QUOTES); 110*24870174SAndreas Gohr $data = json_decode($json, true, 512, JSON_THROW_ON_ERROR); 11196ebed36SAndreas Gohr if ($data === null) { 11279a2d784SGerrit Uitslag return ''; 11306917fceSMichael Große } 114ec57f119SLarsDW223 $data['target'] = strtolower($data['target']); 11596ebed36SAndreas Gohr $data['hid'] = strtolower($data['hid'] ?? ''); 11640868f2fSAdrian Lang 11796ebed36SAndreas Gohr return Event::createAndTrigger( 11896ebed36SAndreas Gohr 'HTML_SECEDIT_BUTTON', 11996ebed36SAndreas Gohr $data, 12096ebed36SAndreas Gohr 'html_secedit_get_button' 12196ebed36SAndreas Gohr ); 12240868f2fSAdrian Lang} 12340868f2fSAdrian Lang 12440868f2fSAdrian Lang/** 12540868f2fSAdrian Lang * prints a section editing button 12640868f2fSAdrian Lang * used as default action form HTML_SECEDIT_BUTTON 12740868f2fSAdrian Lang * 12840868f2fSAdrian Lang * @author Adrian Lang <lang@cosmocode.de> 12942ea7f44SGerrit Uitslag * 13042ea7f44SGerrit Uitslag * @param array $data name, section id and target 13142ea7f44SGerrit Uitslag * @return string html 13240868f2fSAdrian Lang */ 13340868f2fSAdrian Langfunction html_secedit_get_button($data) { 13440868f2fSAdrian Lang global $ID; 13540868f2fSAdrian Lang global $INFO; 13640868f2fSAdrian Lang 1376d9eab4dSMichael Hamann if (!isset($data['name']) || $data['name'] === '') return ''; 13840868f2fSAdrian Lang 13940868f2fSAdrian Lang $name = $data['name']; 14040868f2fSAdrian Lang unset($data['name']); 14140868f2fSAdrian Lang 142905fa971SAdrian Lang $secid = $data['secid']; 143905fa971SAdrian Lang unset($data['secid']); 144905fa971SAdrian Lang 1457afe5d93SSatoshi Sahara $params = array_merge( 146*24870174SAndreas Gohr ['do' => 'edit', 'rev' => $INFO['lastmod'], 'summary' => '['.$name.'] '], 1477afe5d93SSatoshi Sahara $data 1487afe5d93SSatoshi Sahara ); 1497afe5d93SSatoshi Sahara 1507afe5d93SSatoshi Sahara $html = '<div class="secedit editbutton_'.$data['target'] .' editbutton_'.$secid .'">'; 1517afe5d93SSatoshi Sahara $html.= html_btn('secedit', $ID, '', $params, 'post', $name); 1527afe5d93SSatoshi Sahara $html.= '</div>'; 1537afe5d93SSatoshi Sahara return $html; 154f3f0262cSandi} 155f3f0262cSandi 156f3f0262cSandi/** 157d6c9c552Smatthiasgrimm * Just the back to top button (in its own form) 1586b13307fSandi * 1596b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 16042ea7f44SGerrit Uitslag * 16142ea7f44SGerrit Uitslag * @return string html 1626b13307fSandi */ 1636b13307fSandifunction html_topbtn() { 1646b13307fSandi global $lang; 1656b13307fSandi 16679a2d784SGerrit Uitslag return '<a class="nolink" href="#dokuwiki__top">' 1677afe5d93SSatoshi Sahara .'<button class="button" onclick="window.scrollTo(0, 0)" title="'. $lang['btn_top'] .'">' 1687afe5d93SSatoshi Sahara . $lang['btn_top'] 1697afe5d93SSatoshi Sahara .'</button></a>'; 1706b13307fSandi} 1716b13307fSandi 1726b13307fSandi/** 173d67ca2c0Smatthiasgrimm * Displays a button (using its own form) 17435dae8b0SBen Coburn * If tooltip exists, the access key tooltip is replaced. 17515fae107Sandi * 17615fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 17742ea7f44SGerrit Uitslag * 17842ea7f44SGerrit Uitslag * @param string $name 17942ea7f44SGerrit Uitslag * @param string $id 18042ea7f44SGerrit Uitslag * @param string $akey access key 181e3710957SGerrit Uitslag * @param string[] $params key-value pairs added as hidden inputs 18242ea7f44SGerrit Uitslag * @param string $method 18342ea7f44SGerrit Uitslag * @param string $tooltip 18442ea7f44SGerrit Uitslag * @param bool|string $label label text, false: lookup btn_$name in localization 185e824d633SMichael Große * @param string $svg (optional) svg code, inserted into the button 18642ea7f44SGerrit Uitslag * @return string 187f3f0262cSandi */ 188e824d633SMichael Großefunction html_btn($name, $id, $akey, $params, $method = 'get', $tooltip = '', $label = false, $svg = null) { 189f3f0262cSandi global $conf; 190f3f0262cSandi global $lang; 191f3f0262cSandi 192f5baf821SAnika Henke if (!$label) 193f3f0262cSandi $label = $lang['btn_'.$name]; 194f3f0262cSandi 19549c713a3Sandi //filter id (without urlencoding) 19649c713a3Sandi $id = idfilter($id,false); 197f3f0262cSandi 198f3f0262cSandi //make nice URLs even for buttons 1996c7843b5Sandi if ($conf['userewrite'] == 2) { 2006c7843b5Sandi $script = DOKU_BASE.DOKU_SCRIPT.'/'.$id; 2016c7843b5Sandi } elseif ($conf['userewrite']) { 2026c7843b5Sandi $script = DOKU_BASE.$id; 2036c7843b5Sandi } else { 2048b00ebcfSandi $script = DOKU_BASE.DOKU_SCRIPT; 205f3f0262cSandi $params['id'] = $id; 206f3f0262cSandi } 207f3f0262cSandi 2087afe5d93SSatoshi Sahara $html = '<form class="button btn_'.$name.'" method="'.$method.'" action="'.$script.'"><div class="no">'; 209f3f0262cSandi 21006a4bf8fSAndreas Gohr if (is_array($params)) { 2119e491c01SAndreas Gohr foreach ($params as $key => $val) { 2127afe5d93SSatoshi Sahara $html .= '<input type="hidden" name="'.$key.'" value="'.hsc($val).'" />'; 213f3f0262cSandi } 21406a4bf8fSAndreas Gohr } 215f3f0262cSandi 2167afe5d93SSatoshi Sahara $tip = empty($tooltip) ? hsc($label) : hsc($tooltip); 21711ea018fSAndreas Gohr 2187afe5d93SSatoshi Sahara $html .= '<button type="submit" '; 21911ea018fSAndreas Gohr if ($akey) { 22007493d05SAnika Henke $tip .= ' ['.strtoupper($akey).']'; 2217afe5d93SSatoshi Sahara $html .= 'accesskey="'.$akey.'" '; 22235dae8b0SBen Coburn } 2237afe5d93SSatoshi Sahara $html .= 'title="'.$tip.'">'; 224e824d633SMichael Große if ($svg) { 2257afe5d93SSatoshi Sahara $html .= '<span>'. hsc($label) .'</span>'. inlineSVG($svg); 226679dba01SMichael Große } else { 2277afe5d93SSatoshi Sahara $html .= hsc($label); 228679dba01SMichael Große } 2297afe5d93SSatoshi Sahara $html .= '</button>'; 2307afe5d93SSatoshi Sahara $html .= '</div></form>'; 231f3f0262cSandi 2327afe5d93SSatoshi Sahara return $html; 233f3f0262cSandi} 2340747f5d7Sghi/** 2350747f5d7Sghi * show a revision warning 2360747f5d7Sghi * 2370747f5d7Sghi * @author Szymon Olewniczak <dokuwiki@imz.re> 23887f229e8SSatoshi Sahara * @deprecated 2020-07-18 2390747f5d7Sghi */ 240c8556525Sghifunction html_showrev() { 24179a2d784SGerrit Uitslag dbg_deprecated(PageView::class .'::showrev()'); 2420747f5d7Sghi} 243f3f0262cSandi 244f3f0262cSandi/** 24542ea7f44SGerrit Uitslag * Show a wiki page 24615fae107Sandi * 24715fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 24842ea7f44SGerrit Uitslag * 24942ea7f44SGerrit Uitslag * @param null|string $txt wiki text or null for showing $ID 250bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 25115fae107Sandi */ 25211c78c94SAndreas Gohrfunction html_show($txt=null) { 25379a2d784SGerrit Uitslag dbg_deprecated(PageView::class .'::show()'); 254*24870174SAndreas Gohr (new PageView($txt))->show(); 255f3f0262cSandi} 256f3f0262cSandi 257f3f0262cSandi/** 258ee4c4a1bSAndreas Gohr * ask the user about how to handle an exisiting draft 259ee4c4a1bSAndreas Gohr * 260ee4c4a1bSAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 261bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 262ee4c4a1bSAndreas Gohr */ 263ee4c4a1bSAndreas Gohrfunction html_draft() { 26479a2d784SGerrit Uitslag dbg_deprecated(PageDraft::class .'::show()'); 265*24870174SAndreas Gohr (new PageDraft)->show(); 266ee4c4a1bSAndreas Gohr} 267ee4c4a1bSAndreas Gohr 268ee4c4a1bSAndreas Gohr/** 269f3f0262cSandi * Highlights searchqueries in HTML code 27015fae107Sandi * 27115fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 2727209be23SAndreas Gohr * @author Harry Fuecks <hfuecks@gmail.com> 27342ea7f44SGerrit Uitslag * 27442ea7f44SGerrit Uitslag * @param string $html 27542ea7f44SGerrit Uitslag * @param array|string $phrases 27642ea7f44SGerrit Uitslag * @return string html 277f3f0262cSandi */ 278546d3a99SAndreas Gohrfunction html_hilight($html, $phrases) { 2798a803caeSAndreas Gohr $phrases = (array) $phrases; 2808a803caeSAndreas Gohr $phrases = array_map('preg_quote_cb', $phrases); 2818a803caeSAndreas Gohr $phrases = array_map('ft_snippet_re_preprocess', $phrases); 2828a803caeSAndreas Gohr $phrases = array_filter($phrases); 283*24870174SAndreas Gohr 284*24870174SAndreas Gohr $regex = implode('|',$phrases); 28560c15d7dSAndreas Gohr 28660c15d7dSAndreas Gohr if ($regex === '') return $html; 28779a2d784SGerrit Uitslag if (!Clean::isUtf8($regex)) return $html; 288f3f0262cSandi 28979a2d784SGerrit Uitslag return @preg_replace_callback("/((<[^>]*)|$regex)/ui", function ($match) { 290675d8ce4SSatoshi Sahara $hlight = unslash($match[0]); 291675d8ce4SSatoshi Sahara if (!isset($match[2])) { 292688774a0SAnika Henke $hlight = '<span class="search_hit">'.$hlight.'</span>'; 2937209be23SAndreas Gohr } 2947209be23SAndreas Gohr return $hlight; 295675d8ce4SSatoshi Sahara }, $html); 2967209be23SAndreas Gohr} 2977209be23SAndreas Gohr 2987209be23SAndreas Gohr/** 29915fae107Sandi * Display error on locked pages 30015fae107Sandi * 30115fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 3027afe5d93SSatoshi Sahara * @deprecated 2020-07-18 not called anymore, see inc/Action/Locked::tplContent() 30315fae107Sandi */ 304ee20e7d1Sandifunction html_locked() { 30579a2d784SGerrit Uitslag dbg_deprecated(Locked::class .'::showBanner()'); 306*24870174SAndreas Gohr (new Locked())->showBanner(); 307f3f0262cSandi} 308f3f0262cSandi 30915fae107Sandi/** 31015fae107Sandi * list old revisions 31115fae107Sandi * 31215fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 31371726d78SBen Coburn * @author Ben Coburn <btcoburn@silicodon.net> 3148e69fd30SKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net> 315e0c26282SGerrit Uitslag * 316e0c26282SGerrit Uitslag * @param int $first skip the first n changelog lines 31730a159abSSatoshi Sahara * @param string $media_id id of media, or empty for current page 318bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 31915fae107Sandi */ 320a46cc3dcSAndreas Gohrfunction html_revisions($first = -1, $media_id = '') { 32179a2d784SGerrit Uitslag dbg_deprecated(PageRevisions::class .'::show()'); 322b370ebcdSSatoshi Sahara if ($media_id) { 323*24870174SAndreas Gohr (new MediaRevisions($media_id))->show($first); 324b370ebcdSSatoshi Sahara } else { 325b370ebcdSSatoshi Sahara global $INFO; 326*24870174SAndreas Gohr (new PageRevisions($INFO['id']))->show($first); 327b370ebcdSSatoshi Sahara } 328f3f0262cSandi} 329f3f0262cSandi 33015fae107Sandi/** 33115fae107Sandi * display recent changes 33215fae107Sandi * 33315fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 3345749f1ceSmatthiasgrimm * @author Matthias Grimm <matthiasgrimm@users.sourceforge.net> 33571726d78SBen Coburn * @author Ben Coburn <btcoburn@silicodon.net> 3368d40b4b6SKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net> 33742ea7f44SGerrit Uitslag * 33842ea7f44SGerrit Uitslag * @param int $first 33942ea7f44SGerrit Uitslag * @param string $show_changes 340bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 34115fae107Sandi */ 3420739a638SKate Arzamastsevafunction html_recent($first = 0, $show_changes = 'both') { 34379a2d784SGerrit Uitslag dbg_deprecated(Recent::class .'::show()'); 344*24870174SAndreas Gohr (new Recent($first, $show_changes))->show(); 345f3f0262cSandi} 346f3f0262cSandi 34715fae107Sandi/** 34815fae107Sandi * Display page index 34915fae107Sandi * 35015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 35142ea7f44SGerrit Uitslag * 35242ea7f44SGerrit Uitslag * @param string $ns 353bab2b7f0SSatoshi Sahara * @deprecated 2020-07-18 35415fae107Sandi */ 355f3f0262cSandifunction html_index($ns) { 35679a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::show()'); 357*24870174SAndreas Gohr (new Index($ns))->show(); 358f3f0262cSandi} 359f3f0262cSandi 360f3f0262cSandi/** 36189b939d7SSatoshi Sahara * Index tree item formatter for html_buildlist() 36215fae107Sandi * 363f3f0262cSandi * User function for html_buildlist() 36415fae107Sandi * 36515fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 36642ea7f44SGerrit Uitslag * 36742ea7f44SGerrit Uitslag * @param array $item 36842ea7f44SGerrit Uitslag * @return string 3699c8632b4SSatoshi Sahara * @deprecated 2020-07-18 370f3f0262cSandi */ 3719c8632b4SSatoshi Saharafunction html_list_index($item) { 37279a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::formatListItem()'); 373*24870174SAndreas Gohr return (new Index)->formatListItem($item); 374f3f0262cSandi} 375f3f0262cSandi 376f3f0262cSandi/** 37789b939d7SSatoshi Sahara * Index list item formatter for html_buildlist() 378cb70c441Sandi * 379a1dee2b9SAdrian Lang * This user function is used in html_buildlist to build the 380cb70c441Sandi * <li> tags for namespaces when displaying the page index 381cb70c441Sandi * it gives different classes to opened or closed "folders" 382cb70c441Sandi * 383cb70c441Sandi * @author Andreas Gohr <andi@splitbrain.org> 38442ea7f44SGerrit Uitslag * 38542ea7f44SGerrit Uitslag * @param array $item 38642ea7f44SGerrit Uitslag * @return string html 3879c8632b4SSatoshi Sahara * @deprecated 2020-07-18 388cb70c441Sandi */ 3899c8632b4SSatoshi Saharafunction html_li_index($item) { 39079a2d784SGerrit Uitslag dbg_deprecated(Index::class .'::tagListItem()'); 391*24870174SAndreas Gohr return (new Index)->tagListItem($item); 392cb70c441Sandi} 393cb70c441Sandi 394cb70c441Sandi/** 39589b939d7SSatoshi Sahara * Default list item formatter for html_buildlist() 39689b939d7SSatoshi Sahara * 39789b939d7SSatoshi Sahara * @author Andreas Gohr <andi@splitbrain.org> 39889b939d7SSatoshi Sahara * 39989b939d7SSatoshi Sahara * @param array $item 40089b939d7SSatoshi Sahara * @return string html 40189b939d7SSatoshi Sahara * @deprecated 2020-07-18 40289b939d7SSatoshi Sahara */ 40389b939d7SSatoshi Saharafunction html_li_default($item){ 40489b939d7SSatoshi Sahara return '<li class="level'.$item['level'].'">'; 40589b939d7SSatoshi Sahara} 40689b939d7SSatoshi Sahara 40789b939d7SSatoshi Sahara/** 40815fae107Sandi * Build an unordered list 40915fae107Sandi * 410f3f0262cSandi * Build an unordered list from the given $data array 411f3f0262cSandi * Each item in the array has to have a 'level' property 412f3f0262cSandi * the item itself gets printed by the given $func user 413cb70c441Sandi * function. The second and optional function is used to 414cb70c441Sandi * print the <li> tag. Both user function need to accept 415cb70c441Sandi * a single item. 41615fae107Sandi * 417c5a8fd96SAndreas Gohr * Both user functions can be given as array to point to 418c5a8fd96SAndreas Gohr * a member of an object. 419c5a8fd96SAndreas Gohr * 42015fae107Sandi * @author Andreas Gohr <andi@splitbrain.org> 42180679bafSGerrit Uitslag * 42280679bafSGerrit Uitslag * @param array $data array with item arrays 42380679bafSGerrit Uitslag * @param string $class class of ul wrapper 42480679bafSGerrit Uitslag * @param callable $func callback to print an list item 425bde560b4SSatoshi Sahara * @param callable $lifunc (optional) callback to the opening li tag 426bde560b4SSatoshi Sahara * @param bool $forcewrapper (optional) Trigger building a wrapper ul if the first level is 427ae614416SAnika Henke * 0 (we have a root object) or 1 (just the root content) 42880679bafSGerrit Uitslag * @return string html of an unordered list 429f3f0262cSandi */ 430bde560b4SSatoshi Saharafunction html_buildlist($data, $class, $func, $lifunc = null, $forcewrapper = false) { 431*24870174SAndreas Gohr if ($data === []) { 432a1dee2b9SAdrian Lang return ''; 433a1dee2b9SAdrian Lang } 434a1dee2b9SAdrian Lang 4352689c55fSMichael Große $firstElement = reset($data); 4362689c55fSMichael Große $start_level = $firstElement['level']; 4379e4f7880SAdrian Lang $level = $start_level; 4389c8632b4SSatoshi Sahara $html = ''; 439434f5921SHakan Sandell $open = 0; 4409e4f7880SAdrian Lang 441bde560b4SSatoshi Sahara // set callback function to build the <li> tag, formerly defined as html_li_default() 442bde560b4SSatoshi Sahara if (!is_callable($lifunc)) { 443*24870174SAndreas Gohr $lifunc = static fn($item) => '<li class="level'.$item['level'].'">'; 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()'); 502*24870174SAndreas Gohr (new 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; 535*24870174SAndreas Gohr (new 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()'); 580*24870174SAndreas Gohr return (new 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()'); 594*24870174SAndreas Gohr (new 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 610*24870174SAndreas Gohr $shown = []; 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()'); 633*24870174SAndreas Gohr (new 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()'); 645*24870174SAndreas Gohr (new 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()'); 657*24870174SAndreas Gohr (new 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()'); 670*24870174SAndreas Gohr (new 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')) { 757*24870174SAndreas Gohr $apache = []; 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()'); 780*24870174SAndreas Gohr (new 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) { 792*24870174SAndreas Gohr if ($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='#') { 834*24870174SAndreas Gohr return [ 835bde560b4SSatoshi Sahara 'link' => $hash.$link, 836b8595a66SAndreas Gohr 'title' => $text, 837b8595a66SAndreas Gohr 'type' => 'ul', 838bde560b4SSatoshi Sahara 'level' => $level 839*24870174SAndreas Gohr ]; 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) { 869*24870174SAndreas Gohr dbg_deprecated('use ' . Form::class . '::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 902*24870174SAndreas Gohr if(is_null($atts)) $atts = []; 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 1015*24870174SAndreas Gohr $form->addElement(form_makeOpenTag('span', ['class' => $class])); 1016cd2a4cfdSAnika Henke $form->addElement($value); 1017cd2a4cfdSAnika Henke $form->addElement(form_makeCloseTag('span')); 1018cd2a4cfdSAnika Henke } 1019cd2a4cfdSAnika Henke } 1020b0f23f4eSSatoshi Sahara} 1021