* @author Andreas Gohr */ use dokuwiki\Extension\Event; /** * Print the specific HTML meta headers * * Overrides the original version by modifying the headers and the way it is printed * * @author Sascha Leib * @author Andreas Gohr * * @triggers TPL_METAHEADER_OUTPUT * @param bool $alt Should feeds and alternative format links be added? * @return bool */ function my_metaheaders($alt = true) { global $ID; global $REV; global $INFO; global $JSINFO; global $ACT; global $QUERY; global $lang; global $conf; global $updateVersion; /** @var Input $INPUT */ global $INPUT; // prepare the head array $head = array(); // prepare seed for js and css $tseed = $updateVersion; $depends = getConfigFiles('main'); $depends[] = DOKU_CONF."tpl/".$conf['template']."/style.ini"; foreach($depends as $f) $tseed .= @filemtime($f); $tseed = md5($tseed); // the usual stuff $head['meta'][] = array('name'=> 'generator', 'content'=> 'DokuWiki'); if(actionOK('search')) { $head['link'][] = array( 'rel' => 'search', 'type'=> 'application/opensearchdescription+xml', 'href'=> DOKU_BASE.'lib/exe/opensearch.php', 'title'=> $conf['title'] ); } $head['link'][] = array('rel'=> 'start', 'href'=> DOKU_BASE); if(actionOK('index')) { $head['link'][] = array( 'rel' => 'contents', 'href'=> wl($ID, 'do=index', false, '&'), 'title'=> $lang['btn_index'] ); } if (actionOK('manifest')) { $head['link'][] = array('rel'=> 'manifest', 'href'=> DOKU_BASE.'lib/exe/manifest.php'); } $styleUtil = new \dokuwiki\StyleUtils(); $styleIni = $styleUtil->cssStyleini(); $replacements = $styleIni['replacements']; if (!empty($replacements['__theme_color__'])) { $head['meta'][] = array('name' => 'theme-color', 'content' => $replacements['__theme_color__']); } if($alt) { if(actionOK('rss')) { $head['link'][] = array( 'rel' => 'alternate', 'type'=> 'application/rss+xml', 'title'=> $lang['btn_recent'], 'href'=> DOKU_BASE.'feed.php' ); $head['link'][] = array( 'rel' => 'alternate', 'type'=> 'application/rss+xml', 'title'=> $lang['currentns'], 'href' => DOKU_BASE.'feed.php?mode=list&ns='.(isset($INFO) ? $INFO['namespace'] : '') ); } if(($ACT == 'show' || $ACT == 'search') && $INFO['writable']) { $head['link'][] = array( 'rel' => 'edit', 'title'=> $lang['btn_edit'], 'href' => wl($ID, 'do=edit', false, '&') ); } if(actionOK('rss') && $ACT == 'search') { $head['link'][] = array( 'rel' => 'alternate', 'type'=> 'application/rss+xml', 'title'=> $lang['searchresult'], 'href' => DOKU_BASE.'feed.php?mode=search&q='.$QUERY ); } if(actionOK('export_xhtml')) { $head['link'][] = array( 'rel' => 'alternate', 'type'=> 'text/html', 'title'=> $lang['plainhtml'], 'href'=> exportlink($ID, 'xhtml', '', false, '&') ); } if(actionOK('export_raw')) { $head['link'][] = array( 'rel' => 'alternate', 'type'=> 'text/plain', 'title'=> $lang['wikimarkup'], 'href'=> exportlink($ID, 'raw', '', false, '&') ); } } // setup robot tags apropriate for different modes if(($ACT == 'show' || $ACT == 'export_xhtml') && !$REV) { if($INFO['exists']) { //delay indexing: if((time() - $INFO['lastmod']) >= $conf['indexdelay'] && !isHiddenPage($ID) ) { $head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow'); } else { $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow'); } $canonicalUrl = wl($ID, '', true, '&'); if ($ID == $conf['start']) { $canonicalUrl = DOKU_URL; } $head['link'][] = array('rel'=> 'canonical', 'href'=> $canonicalUrl); } else { $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,follow'); } } elseif(defined('DOKU_MEDIADETAIL')) { $head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow'); } else { $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow'); } // set metadata if($ACT == 'show' || $ACT == 'export_xhtml') { // keywords (explicit or implicit) if(!empty($INFO['meta']['subject'])) { $head['meta'][] = array('name'=> 'keywords', 'content'=> join(',', $INFO['meta']['subject'])); } else { $head['meta'][] = array('name'=> 'keywords', 'content'=> str_replace(':', ',', $ID)); } } // load stylesheets $head['link'][] = array( 'rel' => 'stylesheet', 'href'=> DOKU_BASE.'lib/exe/css.php?t='.rawurlencode($conf['template']).'&tseed='.$tseed ); $script = "var NS='".(isset($INFO)?$INFO['namespace']:'')."';"; if($conf['useacl'] && $INPUT->server->str('REMOTE_USER')) { $script .= "var SIG=".toolbar_signature().";"; } jsinfo(); $script .= 'var JSINFO = ' . json_encode($JSINFO).';'; $head['script'][] = array('_data'=> $script); // load jquery $jquery = getCdnUrls(); foreach($jquery as $src) { $head['script'][] = array( 'charset' => 'utf-8', '_data' => '', 'src' => $src, ) + ($conf['defer_js'] ? [ 'defer' => 'defer'] : []); } // load our javascript dispatcher $head['script'][] = array( 'charset'=> 'utf-8', '_data'=> '', 'src' => DOKU_BASE.'lib/exe/js.php'.'?t='.rawurlencode($conf['template']).'&tseed='.$tseed, ) + ($conf['defer_js'] ? [ 'defer' => 'defer'] : []); // trigger event here Event::createAndTrigger('TPL_METAHEADER_OUTPUT', $head, '_my_metaheaders_action', true); return true; } /** * prints the array build by my_metaheaders * * Overrides the original version by adding a tab before each line for neater HTML code * * @author Sascha Leib * @author Andreas Gohr * * @param array $data */ function _my_metaheaders_action($data) { foreach($data as $tag => $inst) { /* if($tag == 'script') { echo "\t\n"; // no scripts for old IE } NO LONGER NEEDED */ foreach($inst as $attr) { if ( empty($attr) ) { continue; } echo "\t<", $tag, ' ', buildAttributes($attr); if(isset($attr['_data']) || $tag == 'script') { if($tag == 'script' && $attr['_data']) $attr['_data'] = "/**/"; echo '>', $attr['_data'], ''; } else { echo '/>'; } echo "\n"; } /* if($tag == 'script') { echo "\t\n"; } -- Not Needed Any Longer */ } } /** * Print the breadcrumbs trace * * Cleanup of the original code to create neater and more accessible HTML * * @author Sascha Leib * @author Andreas Gohr * * @param string $prefix inserted before each line * * @return void */ function my_breadcrumbs($prefix = '') { global $lang; global $conf; //check if enabled if(!$conf['breadcrumbs']) return false; $crumbs = breadcrumbs(); //setup crumb trace /* begin listing */ echo $prefix . "\n"; } /** * Hierarchical breadcrumbs * * Cleanup of the original code to create neater and more accessible HTML * * @author Sascha Leib * @author Andreas Gohr * @author Nigel McNie * @author Sean Coates * @author * * @param string $prefix to be added before each line * */ function my_youarehere($prefix = '') { global $conf; global $ID; global $lang; // check if enabled if(!$conf['youarehere']) return false; $parts = explode(':', $ID); $count = count($parts); echo $prefix . "\n"; } /** * My implementation of the basic userinfo (in the global banner) * * * @author Sascha Leib * * @param string $prefix to be added before each line * * @return void */ function my_userinfo($prefix = '') { global $lang; global $INPUT; // add login/logout button: $items = array_reverse((new \dokuwiki\Menu\UserMenu())->getItems()); foreach($items as $it) { $typ = $it->getType(); if ($typ === 'profile') { echo $prefix . "
  • " . $lang['loggedinas'] . ' ' . userlink() . "
  • \n"; } else { echo $prefix . "
  • getLink()) . '" title="' . $it->getTitle() . '">' . $it->getLabel() . "
  • \n"; } } } /** *Inserts a cleaner version of the TOC * * This is an update of the original function that renders the TOC directly. * * @author Sascha Leib * @author Andreas Gohr * * @param string $prefix to be added before each line * * @return void */ function my_toc($prefix = '') { global $TOC; global $ACT; global $ID; global $REV; global $INFO; global $conf; global $lang; $toc = array(); if(is_array($TOC)) { // if a TOC was prepared in global scope, always use it $toc = $TOC; } elseif(($ACT == 'show' || substr($ACT, 0, 6) == 'export') && !$REV && $INFO['exists']) { // get TOC from metadata, render if neccessary $meta = p_get_metadata($ID, '', METADATA_RENDER_USING_CACHE); if(isset($meta['internal']['toc'])) { $tocok = $meta['internal']['toc']; } else { $tocok = true; } $toc = isset($meta['description']['tableofcontents']) ? $meta['description']['tableofcontents'] : null; if(!$tocok || !is_array($toc) || !$conf['tocminheads'] || count($toc) < $conf['tocminheads']) { $toc = array(); } } elseif($ACT == 'admin') { // try to load admin plugin TOC /** @var $plugin AdminPlugin */ if ($plugin = plugin_getRequestAdminPlugin()) { $toc = $plugin->getTOC(); $TOC = $toc; // avoid later rebuild } } /* Build the hierarchical list of headline links: */ if (count($toc) >= intval($conf['tocminheads'])) { echo $prefix . "\n"; } } /** * Print last change date * * @author Sascha Leib * * @param string $prefix to be added before each line * * @return void */ function my_lastchange($prefix = '') { global $lang; global $INFO; $format = '%Y-%m-%dT%T%z'; /* 2021-21-05T16:45:12+02:00 */ $date = $INFO['lastmod']; echo $prefix . '' . $lang['lastmod'] . "\n"; echo $prefix . '\n"; echo $prefix .'' . $lang['by'] . ' ' . editorinfo($INFO['editor']) . "\n"; }