xref: /template/ad-hominem/my_template.php (revision 24379368f37e421b5af712f4b074c663da00649d)
1e5d0cb92SSascha Leib<?php
2e5d0cb92SSascha Leib/**
3e5d0cb92SSascha Leib * Overwriting DokuWiki template functions
4e5d0cb92SSascha Leib *
5e5d0cb92SSascha Leib * @license	GPL 2 (http://www.gnu.org/licenses/gpl.html)
6e5d0cb92SSascha Leib * @author	Sascha Leib <sascha@leib.be>
7e5d0cb92SSascha Leib * @author	Andreas Gohr <andi@splitbrain.org>
8e5d0cb92SSascha Leib */
9e5d0cb92SSascha Leib
10e5d0cb92SSascha Leibuse dokuwiki\Extension\Event;
114095125cSsaschaleibuse dokuwiki\File\PageResolver;
12e5d0cb92SSascha Leib
13e5d0cb92SSascha Leib/**
14e5d0cb92SSascha Leib * Print the specific HTML meta headers
15e5d0cb92SSascha Leib *
16e5d0cb92SSascha Leib * Overrides the original version by modifying the headers and the way it is printed
17e5d0cb92SSascha Leib *
18e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
19e5d0cb92SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
20e5d0cb92SSascha Leib *
21e5d0cb92SSascha Leib * @triggers TPL_METAHEADER_OUTPUT
22e5d0cb92SSascha Leib * @param	bool $alt Should feeds and alternative format links be added?
23e5d0cb92SSascha Leib * @return	bool
24e5d0cb92SSascha Leib */
25e5d0cb92SSascha Leibfunction my_metaheaders($alt = true) {
26e5d0cb92SSascha Leib	global $ID;
27e5d0cb92SSascha Leib	global $REV;
28e5d0cb92SSascha Leib	global $INFO;
29e5d0cb92SSascha Leib	global $JSINFO;
30e5d0cb92SSascha Leib	global $ACT;
31e5d0cb92SSascha Leib	global $QUERY;
32e5d0cb92SSascha Leib	global $lang;
33e5d0cb92SSascha Leib	global $conf;
34e5d0cb92SSascha Leib	global $updateVersion;
35e5d0cb92SSascha Leib	/** @var Input $INPUT */
36e5d0cb92SSascha Leib	global $INPUT;
37e5d0cb92SSascha Leib
38e5d0cb92SSascha Leib	// prepare the head array
39e5d0cb92SSascha Leib	$head = array();
40e5d0cb92SSascha Leib
41e5d0cb92SSascha Leib	// prepare seed for js and css
42e5d0cb92SSascha Leib	$tseed = $updateVersion;
43e5d0cb92SSascha Leib	$depends = getConfigFiles('main');
44e5d0cb92SSascha Leib	$depends[] = DOKU_CONF."tpl/".$conf['template']."/style.ini";
45e5d0cb92SSascha Leib	foreach($depends as $f) $tseed .= @filemtime($f);
46e5d0cb92SSascha Leib	$tseed = md5($tseed);
47e5d0cb92SSascha Leib
48e5d0cb92SSascha Leib	// Open Graph information
49e5d0cb92SSascha Leib	$meta = p_get_metadata($ID);
5075b78f02Ssaschaleib	if (is_array($meta) && array_key_exists('title', $meta) && $meta['title'] !== null) {
51e5d0cb92SSascha Leib		$head['meta'][] = array('property' => 'og:title', 'content' => tpl_pagetitle($ID, true));
52e5d0cb92SSascha Leib		$head['meta'][] = array('property' => 'og:site_name ', 'content' => $conf['title']);
53e5d0cb92SSascha Leib		$head['meta'][] = array('property' => 'og:type', 'content' => 'website');
54e5d0cb92SSascha Leib		$head['meta'][] = array('property' => 'og:url', 'content' => wl($ID, '', true, '&'));
55e5d0cb92SSascha Leib
56b97c7e78Ssaschaleib		if (array_key_exists('description', $meta) && is_array($meta['description'])) {
57b97c7e78Ssaschaleib			if (array_key_exists('abstract', $meta['description'])) {
585dd187b0SSascha Leib				$parts = explode(NL, $meta['description']['abstract']);
59394615b3Ssaschaleib
60394615b3Ssaschaleib				if (is_array($parts) && array_key_exists(2, $parts)) {
61e5d0cb92SSascha Leib					$head['meta'][] = array('property' => 'og:description', 'content' => $parts[2]);
623f9a5510Ssaschaleib
633f9a5510Ssaschaleib					// Bing insists in a non-og description:
6422f0dafcSsaschaleib					$head['meta'][] = array('name' => 'description', 'content' => $parts[2]);
65e5d0cb92SSascha Leib				}
66394615b3Ssaschaleib			}
67b97c7e78Ssaschaleib		}
68b97c7e78Ssaschaleib	}
69e5d0cb92SSascha Leib
70e5d0cb92SSascha Leib	// the usual stuff
71e5d0cb92SSascha Leib	$head['meta'][] = array('name'=> 'generator', 'content'=> 'DokuWiki');
72e5d0cb92SSascha Leib	if(actionOK('search')) {
73e5d0cb92SSascha Leib		$head['link'][] = array(
74e5d0cb92SSascha Leib			'rel' => 'search', 'type'=> 'application/opensearchdescription+xml',
75e5d0cb92SSascha Leib			'href'=> DOKU_BASE.'lib/exe/opensearch.php', 'title'=> $conf['title']
76e5d0cb92SSascha Leib		);
77e5d0cb92SSascha Leib	}
78e5d0cb92SSascha Leib
79e5d0cb92SSascha Leib	$head['link'][] = array('rel'=> 'start', 'href'=> DOKU_BASE);
80e5d0cb92SSascha Leib	if(actionOK('index')) {
81e5d0cb92SSascha Leib		$head['link'][] = array(
82e5d0cb92SSascha Leib			'rel' => 'contents', 'href'=> wl($ID, 'do=index', false, '&'),
83e5d0cb92SSascha Leib			'title'=> $lang['btn_index']
84e5d0cb92SSascha Leib		);
85e5d0cb92SSascha Leib	}
86e5d0cb92SSascha Leib
87e5d0cb92SSascha Leib	if (actionOK('manifest')) {
88e5d0cb92SSascha Leib		$head['link'][] = array('rel'=> 'manifest', 'href'=> DOKU_BASE.'lib/exe/manifest.php');
89e5d0cb92SSascha Leib	}
90e5d0cb92SSascha Leib
91e5d0cb92SSascha Leib	$styleUtil = new \dokuwiki\StyleUtils();
92e5d0cb92SSascha Leib	$styleIni = $styleUtil->cssStyleini();
93e5d0cb92SSascha Leib	$replacements = $styleIni['replacements'];
94e5d0cb92SSascha Leib	if (!empty($replacements['__theme_color__'])) {
9534d27ad1Ssaschaleib		$head['meta'][] = array(
9634d27ad1Ssaschaleib			'name' => 'theme-color',
9734d27ad1Ssaschaleib			'content' => $replacements['__theme_color__']
9834d27ad1Ssaschaleib		);
99e5d0cb92SSascha Leib	}
100e5d0cb92SSascha Leib
101e5d0cb92SSascha Leib	if($alt) {
102e5d0cb92SSascha Leib		if(actionOK('rss')) {
103e5d0cb92SSascha Leib			$head['link'][] = array(
104e5d0cb92SSascha Leib				'rel'  => 'alternate', 'type'=> 'application/rss+xml',
105e5d0cb92SSascha Leib				'title'=> $lang['btn_recent'], 'href'=> DOKU_BASE.'feed.php'
106e5d0cb92SSascha Leib			);
107e5d0cb92SSascha Leib			$head['link'][] = array(
108e5d0cb92SSascha Leib				'rel'  => 'alternate', 'type'=> 'application/rss+xml',
109e5d0cb92SSascha Leib				'title'=> $lang['currentns'],
110e5d0cb92SSascha Leib				'href' => DOKU_BASE.'feed.php?mode=list&ns='.(isset($INFO) ? $INFO['namespace'] : '')
111e5d0cb92SSascha Leib			);
112e5d0cb92SSascha Leib		}
113e5d0cb92SSascha Leib		if(($ACT == 'show' || $ACT == 'search') && $INFO['writable']) {
114e5d0cb92SSascha Leib			$head['link'][] = array(
115e5d0cb92SSascha Leib				'rel'  => 'edit',
116e5d0cb92SSascha Leib				'title'=> $lang['btn_edit'],
117e5d0cb92SSascha Leib				'href' => wl($ID, 'do=edit', false, '&')
118e5d0cb92SSascha Leib			);
119e5d0cb92SSascha Leib		}
120e5d0cb92SSascha Leib
121e5d0cb92SSascha Leib		if(actionOK('rss') && $ACT == 'search') {
122e5d0cb92SSascha Leib			$head['link'][] = array(
123e5d0cb92SSascha Leib				'rel'  => 'alternate', 'type'=> 'application/rss+xml',
124e5d0cb92SSascha Leib				'title'=> $lang['searchresult'],
125e5d0cb92SSascha Leib				'href' => DOKU_BASE.'feed.php?mode=search&q='.$QUERY
126e5d0cb92SSascha Leib			);
127e5d0cb92SSascha Leib		}
128e5d0cb92SSascha Leib
129e5d0cb92SSascha Leib		if(actionOK('export_xhtml')) {
130e5d0cb92SSascha Leib			$head['link'][] = array(
131e5d0cb92SSascha Leib				'rel' => 'alternate', 'type'=> 'text/html', 'title'=> $lang['plainhtml'],
132e5d0cb92SSascha Leib				'href'=> exportlink($ID, 'xhtml', '', false, '&')
133e5d0cb92SSascha Leib			);
134e5d0cb92SSascha Leib		}
135e5d0cb92SSascha Leib
136e5d0cb92SSascha Leib		if(actionOK('export_raw')) {
137e5d0cb92SSascha Leib			$head['link'][] = array(
138e5d0cb92SSascha Leib				'rel' => 'alternate', 'type'=> 'text/plain', 'title'=> $lang['wikimarkup'],
139e5d0cb92SSascha Leib				'href'=> exportlink($ID, 'raw', '', false, '&')
140e5d0cb92SSascha Leib			);
141e5d0cb92SSascha Leib		}
142e5d0cb92SSascha Leib	}
143e5d0cb92SSascha Leib
144e5d0cb92SSascha Leib	// setup robot tags apropriate for different modes
145e5d0cb92SSascha Leib	if(($ACT == 'show' || $ACT == 'export_xhtml') && !$REV) {
146e5d0cb92SSascha Leib		if($INFO['exists']) {
147e5d0cb92SSascha Leib			//delay indexing:
148e5d0cb92SSascha Leib			if((time() - $INFO['lastmod']) >= $conf['indexdelay'] && !isHiddenPage($ID) ) {
149e5d0cb92SSascha Leib				$head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow');
150e5d0cb92SSascha Leib			} else {
151e5d0cb92SSascha Leib				$head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow');
152e5d0cb92SSascha Leib			}
153e5d0cb92SSascha Leib			$canonicalUrl = wl($ID, '', true, '&');
154e5d0cb92SSascha Leib			if ($ID == $conf['start']) {
155e5d0cb92SSascha Leib				$canonicalUrl = DOKU_URL;
156e5d0cb92SSascha Leib			}
157e5d0cb92SSascha Leib			$head['link'][] = array('rel'=> 'canonical', 'href'=> $canonicalUrl);
158e5d0cb92SSascha Leib		} else {
159e5d0cb92SSascha Leib			$head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,follow');
160e5d0cb92SSascha Leib		}
161e5d0cb92SSascha Leib	} elseif(defined('DOKU_MEDIADETAIL')) {
162e5d0cb92SSascha Leib		$head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow');
163e5d0cb92SSascha Leib	} else {
164e5d0cb92SSascha Leib		$head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow');
165e5d0cb92SSascha Leib	}
166e5d0cb92SSascha Leib
167e5d0cb92SSascha Leib	// set metadata
168e5d0cb92SSascha Leib	if($ACT == 'show' || $ACT == 'export_xhtml') {
169e5d0cb92SSascha Leib		// keywords (explicit or implicit)
170e5d0cb92SSascha Leib		if(!empty($INFO['meta']['subject'])) {
171e5d0cb92SSascha Leib			$head['meta'][] = array('name'=> 'keywords', 'content'=> join(',', $INFO['meta']['subject']));
172e5d0cb92SSascha Leib		} else {
173e5d0cb92SSascha Leib			$head['meta'][] = array('name'=> 'keywords', 'content'=> str_replace(':', ',', $ID));
174e5d0cb92SSascha Leib		}
175e5d0cb92SSascha Leib	}
176e5d0cb92SSascha Leib
177e5d0cb92SSascha Leib	// load stylesheets
178e5d0cb92SSascha Leib	$head['link'][] = array(
179e5d0cb92SSascha Leib		'rel' => 'stylesheet',
180565472e4SSascha Leib		'href'=> DOKU_BASE . 'lib/exe/css.php?t='.rawurlencode($conf['template']).'&tseed='.$tseed,
181565472e4SSascha Leib		'defer' => 'defer'
182e5d0cb92SSascha Leib	);
183e5d0cb92SSascha Leib
1845dd187b0SSascha Leib	$script = "var NS='".(isset($INFO)?$INFO['namespace']:'')."';".DOKU_LF.DOKU_TAB.DOKU_TAB;
185e5d0cb92SSascha Leib	if($conf['useacl'] && $INPUT->server->str('REMOTE_USER')) {
1865dd187b0SSascha Leib		$script .= "var SIG=".toolbar_signature().";".DOKU_LF.DOKU_TAB.DOKU_TAB;
187e5d0cb92SSascha Leib	}
188e5d0cb92SSascha Leib
189e5d0cb92SSascha Leib	if($conf['basedir']) {
1905dd187b0SSascha Leib		$script .= 'var BASEDIR="'.$conf['basedir']."\";".DOKU_LF.DOKU_TAB.DOKU_TAB;
191e5d0cb92SSascha Leib	}
192e5d0cb92SSascha Leib
193e5d0cb92SSascha Leib	jsinfo();
194e5d0cb92SSascha Leib	$script .= 'var JSINFO = ' . json_encode($JSINFO).';';
195e5d0cb92SSascha Leib	$head['script'][] = array('_data'=> $script);
196e5d0cb92SSascha Leib
197e5d0cb92SSascha Leib	// load jquery
198e5d0cb92SSascha Leib	$jquery = getCdnUrls();
199e5d0cb92SSascha Leib	foreach($jquery as $src) {
200e5d0cb92SSascha Leib		$head['script'][] = array(
201e5d0cb92SSascha Leib			/* 'charset' => 'utf-8', -- obsolete */
202e5d0cb92SSascha Leib			'_data' => '',
203e5d0cb92SSascha Leib			'src' => $src,
204e5d0cb92SSascha Leib		) + ($conf['defer_js'] ? [ 'defer' => 'defer'] : []);
205e5d0cb92SSascha Leib	}
206e5d0cb92SSascha Leib
207e5d0cb92SSascha Leib	// load our javascript dispatcher
208e5d0cb92SSascha Leib	$head['script'][] = array(
209e5d0cb92SSascha Leib		/* 'charset'=> 'utf-8', -- obsolete */
210e5d0cb92SSascha Leib		'_data'=> '',
211e5d0cb92SSascha Leib		'src' => DOKU_BASE . 'lib/exe/js.php'.'?t='.rawurlencode($conf['template']).'&tseed='.$tseed,
212e5d0cb92SSascha Leib	) + ($conf['defer_js'] ? [ 'defer' => 'defer'] : []);
213e5d0cb92SSascha Leib
214e5d0cb92SSascha Leib	// trigger event here
215e5d0cb92SSascha Leib	Event::createAndTrigger('TPL_METAHEADER_OUTPUT', $head, '_my_metaheaders_action', true);
216e5d0cb92SSascha Leib	return true;
217e5d0cb92SSascha Leib}
218e5d0cb92SSascha Leib
219e5d0cb92SSascha Leib/**
220e5d0cb92SSascha Leib * prints the array build by my_metaheaders
221e5d0cb92SSascha Leib *
222e5d0cb92SSascha Leib * Overrides the original version by adding a tab before each line for neater HTML code
223e5d0cb92SSascha Leib *
224e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
225e5d0cb92SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
226e5d0cb92SSascha Leib *
227e5d0cb92SSascha Leib * @param array $data
228e5d0cb92SSascha Leib */
229e5d0cb92SSascha Leibfunction _my_metaheaders_action($data) {
230e5d0cb92SSascha Leib	foreach($data as $tag => $inst) {
231e5d0cb92SSascha Leib		foreach($inst as $attr) {
232e5d0cb92SSascha Leib			if ( empty($attr) ) { continue; }
2335dd187b0SSascha Leib			echo DOKU_TAB . '<', $tag, ' ', buildAttributes($attr);
234c8a4fd95SSascha Leib			if($tag == 'script' && isset($attr['_data'])) {
235445d91c7SSascha Leib				/* $attr['_data'] = "<![CDATA[".NL. DOKU_TAB . DOKU_TAB .
236e5d0cb92SSascha Leib					$attr['_data'].
237445d91c7SSascha Leib					NL . DOKU_TAB . ' ]]>'; */
2385061d95dSSascha Leib
239e5d0cb92SSascha Leib				echo '>', $attr['_data'], '</', $tag, '>';
240e5d0cb92SSascha Leib			} else {
241445d91c7SSascha Leib				echo '>';
242445d91c7SSascha Leib				if ($tag == 'script') {
243445d91c7SSascha Leib					echo '</', $tag, '>';
244445d91c7SSascha Leib				}
245e5d0cb92SSascha Leib			}
2465dd187b0SSascha Leib			echo DOKU_LF;
247e5d0cb92SSascha Leib		}
248e5d0cb92SSascha Leib	}
249e5d0cb92SSascha Leib}
250e5d0cb92SSascha Leib
251e5d0cb92SSascha Leib/**
25276a91b98Ssaschaleib * get a link to the homepage.
25376a91b98Ssaschaleib *
25476a91b98Ssaschaleib * wraps the original wl() function to allow overriding in the options
25576a91b98Ssaschaleib *
25676a91b98Ssaschaleib * @author Sascha Leib <sascha@leib.be>
25776a91b98Ssaschaleib *
25876a91b98Ssaschaleib * @returns string (link)
25976a91b98Ssaschaleib */
26076a91b98Ssaschaleibfunction my_homelink() {
26176a91b98Ssaschaleib	global $conf;
26276a91b98Ssaschaleib
26376a91b98Ssaschaleib	$hl = trim(tpl_getConf('homelink'));
26476a91b98Ssaschaleib
26576a91b98Ssaschaleib	if ( $hl !== '' ) {
26676a91b98Ssaschaleib		return $hl;
26776a91b98Ssaschaleib	} else {
26876a91b98Ssaschaleib		return wl(); // default homelink
26976a91b98Ssaschaleib	}
27076a91b98Ssaschaleib}
27176a91b98Ssaschaleib
27276a91b98Ssaschaleib/**
273e5d0cb92SSascha Leib * Print the breadcrumbs trace
274e5d0cb92SSascha Leib *
275e5d0cb92SSascha Leib * Cleanup of the original code to create neater and more accessible HTML
276e5d0cb92SSascha Leib *
277e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
278e5d0cb92SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
279e5d0cb92SSascha Leib *
280e5d0cb92SSascha Leib * @param string $prefix inserted before each line
281e5d0cb92SSascha Leib *
282e5d0cb92SSascha Leib * @return void
283e5d0cb92SSascha Leib */
284e5d0cb92SSascha Leibfunction my_breadcrumbs($prefix = '') {
285e5d0cb92SSascha Leib	global $lang;
286e5d0cb92SSascha Leib	global $conf;
287e5d0cb92SSascha Leib
288e5d0cb92SSascha Leib	//check if enabled
289e5d0cb92SSascha Leib	if(!$conf['breadcrumbs']) return false;
290e5d0cb92SSascha Leib
291e5d0cb92SSascha Leib	$crumbs = breadcrumbs(); //setup crumb trace
292e5d0cb92SSascha Leib
293e5d0cb92SSascha Leib	/* begin listing */
2945dd187b0SSascha Leib	echo $prefix . '<nav id="navBreadCrumbs">'.NL;
2955dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<h4>' . $lang['breadcrumb'] . '</h4>'.NL;
2965dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<ol reversed>'.NL;
297e5d0cb92SSascha Leib
298e5d0cb92SSascha Leib	$last = count($crumbs);
299e5d0cb92SSascha Leib	$i	= 0;
300e5d0cb92SSascha Leib	foreach($crumbs as $id => $name) {
301e5d0cb92SSascha Leib		$i++;
3025dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li' . ($i == $last ? ' class="current"' : '') . '><bdi>' . tpl_link(wl($id), hsc($name), '', true) .  '</bdi></li>'.NL;
303e5d0cb92SSascha Leib	}
3045dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '</ol>'.NL;
3055dd187b0SSascha Leib	echo $prefix . '</nav>'.NL;
306e5d0cb92SSascha Leib}
307e5d0cb92SSascha Leib
308e5d0cb92SSascha Leib/**
309e5d0cb92SSascha Leib * Hierarchical breadcrumbs
310e5d0cb92SSascha Leib *
311e5d0cb92SSascha Leib * Cleanup of the original code to create neater and more accessible HTML
312e5d0cb92SSascha Leib *
313e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
314e5d0cb92SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
315e5d0cb92SSascha Leib * @author Nigel McNie <oracle.shinoda@gmail.com>
316e5d0cb92SSascha Leib * @author Sean Coates <sean@caedmon.net>
317e5d0cb92SSascha Leib * @author <fredrik@averpil.com>
318e5d0cb92SSascha Leib *
319e5d0cb92SSascha Leib * @param  string $prefix to be added before each line
320e5d0cb92SSascha Leib *
321e5d0cb92SSascha Leib */
322e5d0cb92SSascha Leibfunction my_youarehere($prefix = '') {
323e5d0cb92SSascha Leib	global $conf;
324e5d0cb92SSascha Leib	global $ID;
325e5d0cb92SSascha Leib	global $lang;
326e5d0cb92SSascha Leib
327e5d0cb92SSascha Leib	// check if enabled
328e5d0cb92SSascha Leib	if(!$conf['youarehere']) return false;
329e5d0cb92SSascha Leib
330e5d0cb92SSascha Leib	$parts = explode(':', $ID);
331e5d0cb92SSascha Leib	$count = count($parts);
33219b66c8eSSascha Leib	$isdir = ( $parts[$count-1] == $conf['start']);
333e5d0cb92SSascha Leib
33476a91b98Ssaschaleib	$hl = trim(tpl_getConf('homelink'));
33576a91b98Ssaschaleib
3365dd187b0SSascha Leib	echo $prefix . '<nav id="navYouAreHere">'.NL;
3375dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<h4>' . $lang['youarehere'] . '</h4>'.NL;
3385dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<ol>'.NL;
339e5d0cb92SSascha Leib
340e5d0cb92SSascha Leib	// always print the startpage
34176a91b98Ssaschaleib	if ( $hl !== '' ) {
3425dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li class="home">' . tpl_link( $hl, htmlentities(tpl_getLang('homepage')), ' title="' . htmlentities(tpl_getLang('homepage')) . '"', true) . '</li>'.NL;
3435dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li>' . tpl_pagelink(':'.$conf['start'], null, true) . '</li>'.NL;
34476a91b98Ssaschaleib	} else {
3455dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li class="home">' . tpl_pagelink(':'.$conf['start'], null, true) . '</li>'.NL;
34676a91b98Ssaschaleib	}
347e5d0cb92SSascha Leib
348e5d0cb92SSascha Leib	// print intermediate namespace links
3494095125cSsaschaleib	$page = '';
350e5d0cb92SSascha Leib	for($i = 0; $i < $count - 1; $i++) {
3514095125cSsaschaleib		$part = $parts[$i];
3524095125cSsaschaleib		$page .= $part . ':';
353e5d0cb92SSascha Leib
35419b66c8eSSascha Leib		if ($i == $count-2 && $isdir)  break; // Skip last if it is an index page
35519b66c8eSSascha Leib
3565dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li>' . tpl_pagelink($page, null, true) . '</li>'.NL;
357e5d0cb92SSascha Leib	}
358e5d0cb92SSascha Leib
35919b66c8eSSascha Leib	// chould the current page be included in the listing?
36019b66c8eSSascha Leib	$trail = tpl_getConf('navtrail');
36119b66c8eSSascha Leib
36219b66c8eSSascha Leib	if ($trail !== 'none' && $trail !== '') {
3634095125cSsaschaleib
3645dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '<li class="current">';
36519b66c8eSSascha Leib		if ($trail == 'text') {
3664095125cSsaschaleib			echo tpl_pagetitle($page . $parts[$count-1], true);
36719b66c8eSSascha Leib		} else if ($trail == 'link') {
3684095125cSsaschaleib			echo tpl_pagelink($page . $parts[$count-1], null, true);
36919b66c8eSSascha Leib		}
3705dd187b0SSascha Leib		echo '</li>'.NL;
37119b66c8eSSascha Leib	}
372e5d0cb92SSascha Leib
3735dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '</ol>'.NL;
3745dd187b0SSascha Leib	echo $prefix . '</nav>'.NL;
375e5d0cb92SSascha Leib}
376e5d0cb92SSascha Leib
377e5d0cb92SSascha Leib/**
378e5d0cb92SSascha Leib * My implementation of the basic userinfo (in the global banner)
379e5d0cb92SSascha Leib *
380e5d0cb92SSascha Leib *
381e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
382e5d0cb92SSascha Leib *
383e5d0cb92SSascha Leib * @param  string $prefix to be added before each line
384e5d0cb92SSascha Leib *
385e5d0cb92SSascha Leib * @return void
386e5d0cb92SSascha Leib */
387e5d0cb92SSascha Leibfunction my_userinfo($prefix = '') {
388e5d0cb92SSascha Leib	global $lang;
389e5d0cb92SSascha Leib	global $INPUT;
390e5d0cb92SSascha Leib
391e5d0cb92SSascha Leib	// add login/logout button:
392e5d0cb92SSascha Leib	$items = (new \dokuwiki\Menu\UserMenu())->getItems();
393e5d0cb92SSascha Leib	foreach($items as $it) {
394e5d0cb92SSascha Leib		$typ = $it->getType();
39533aeef3fSTim Kuhlbusch
396e2e54d0aSSascha Leib		if ($typ === 'profile') { // special case for user profile:
397e2e54d0aSSascha Leib
398e2e54d0aSSascha Leib			echo $prefix . '<li class="action profile"><span class="sronly">' . $lang['loggedinas'] .
3997f40b6b7SSascha Leib				' </span><a href="' . htmlentities($it->getLink()) . '" title="' . $it->getTitle() . '">' .
4005dd187b0SSascha Leib				userlink() . "</a></li>".NL;
401e2e54d0aSSascha Leib
402e2e54d0aSSascha Leib		} else {
403e2e54d0aSSascha Leib
4045dd187b0SSascha Leib			echo $prefix . "<li class=\"action $typ\">" . '<a href="' . htmlentities($it->getLink()) .
405e2e54d0aSSascha Leib				'" title="' . $it->getTitle() . '">' . ($typ === 'profile'? userlink() : $it->getLabel() ) .
4065dd187b0SSascha Leib				'</a></li>'.NL;
407e2e54d0aSSascha Leib		}
408e5d0cb92SSascha Leib	}
409e5d0cb92SSascha Leib}
410e5d0cb92SSascha Leib
411e5d0cb92SSascha Leib/**
412e5d0cb92SSascha Leib *Inserts a cleaner version of the TOC
413e5d0cb92SSascha Leib *
414e5d0cb92SSascha Leib * This is an update of the original function that renders the TOC directly.
415e5d0cb92SSascha Leib *
416e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
417e5d0cb92SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
418e5d0cb92SSascha Leib *
419e5d0cb92SSascha Leib * @param  string $prefix to be added before each line
420e5d0cb92SSascha Leib *
421e5d0cb92SSascha Leib * @return void
422e5d0cb92SSascha Leib */
423e5d0cb92SSascha Leibfunction my_toc($prefix = '') {
424e5d0cb92SSascha Leib	global $TOC;
425e5d0cb92SSascha Leib	global $ACT;
426e5d0cb92SSascha Leib	global $ID;
427e5d0cb92SSascha Leib	global $REV;
428e5d0cb92SSascha Leib	global $INFO;
429e5d0cb92SSascha Leib	global $conf;
430e5d0cb92SSascha Leib	global $lang;
431e5d0cb92SSascha Leib	$toc = array();
432e5d0cb92SSascha Leib
43303583c1aSSascha Leib	// default TOC State:
43403583c1aSSascha Leib	$tocState = 'hide';
43503583c1aSSascha Leib
436e5d0cb92SSascha Leib	if(is_array($TOC)) {
437e5d0cb92SSascha Leib		// if a TOC was prepared in global scope, always use it
438e5d0cb92SSascha Leib		$toc = $TOC;
439e5d0cb92SSascha Leib	} elseif(($ACT == 'show' || substr($ACT, 0, 6) == 'export') && !$REV && $INFO['exists']) {
44003583c1aSSascha Leib
44103583c1aSSascha Leib		// read TOC state from the user config:
44203583c1aSSascha Leib		$tocState = tpl_getConf('tocstyle', $tocState);
44303583c1aSSascha Leib
444e5d0cb92SSascha Leib		// get TOC from metadata, render if neccessary
445e5d0cb92SSascha Leib		$meta = p_get_metadata($ID, '', METADATA_RENDER_USING_CACHE);
446e5d0cb92SSascha Leib		if(isset($meta['internal']['toc'])) {
447e5d0cb92SSascha Leib			$tocok = $meta['internal']['toc'];
448e5d0cb92SSascha Leib		} else {
449e5d0cb92SSascha Leib			$tocok = true;
450e5d0cb92SSascha Leib		}
451e5d0cb92SSascha Leib		$toc = isset($meta['description']['tableofcontents']) ? $meta['description']['tableofcontents'] : null;
452e5d0cb92SSascha Leib		if(!$tocok || !is_array($toc) || !$conf['tocminheads'] || count($toc) < $conf['tocminheads']) {
453e5d0cb92SSascha Leib			$toc = array();
454e5d0cb92SSascha Leib		}
455e5d0cb92SSascha Leib	} elseif($ACT == 'admin') {
456e5d0cb92SSascha Leib		// try to load admin plugin TOC
457e5d0cb92SSascha Leib		/** @var $plugin AdminPlugin */
458e5d0cb92SSascha Leib		if ($plugin = plugin_getRequestAdminPlugin()) {
459e5d0cb92SSascha Leib			$toc = $plugin->getTOC();
460e5d0cb92SSascha Leib			$TOC = $toc; // avoid later rebuild
461e5d0cb92SSascha Leib		}
462e5d0cb92SSascha Leib	}
463e5d0cb92SSascha Leib
464e5d0cb92SSascha Leib	/* Build the hierarchical list of headline links: */
465e5d0cb92SSascha Leib	if (count($toc) >= intval($conf['tocminheads'])) {
46603583c1aSSascha Leib		echo $prefix . '<aside id="toc" class="toggle '.$tocState.'">'.NL;
4675dd187b0SSascha Leib		echo $prefix . DOKU_TAB . '<button type="button" id="toc-menubutton" class="tg_button" title="' . htmlentities($lang['toc']) . '" aria-haspopup="true" aria-controls="toc-menu"><span>' . htmlentities($lang['toc']) . '</span></button>'.NL;
4685dd187b0SSascha Leib		echo $prefix . DOKU_TAB . '<nav id="toc-menu" class="tg_content" role="menu" aria-labelledby="toc-menubutton">';
469602dcfebSsaschaleib		$level = 0;
470e5d0cb92SSascha Leib		foreach($toc as $it) {
471e5d0cb92SSascha Leib
472e5d0cb92SSascha Leib			$nl = intval($it['level']);
473e5d0cb92SSascha Leib			$cp = ($nl <=> $level);
474e5d0cb92SSascha Leib
475e5d0cb92SSascha Leib			if ($cp > 0) {
476602dcfebSsaschaleib				while ($level < $nl) {
4775dd187b0SSascha Leib					echo DOKU_LF . $prefix . str_repeat(DOKU_TAB, $level*2 + 2) . '<ol>'.NL;
478602dcfebSsaschaleib					$level++;
479602dcfebSsaschaleib				}
480e5d0cb92SSascha Leib			} else if ($cp < 0) {
481602dcfebSsaschaleib				while ($level > $nl) {
4825dd187b0SSascha Leib					echo DOKU_LF . $prefix . str_repeat(DOKU_TAB, $level*2) . '</ol>'.NL;
4835dd187b0SSascha Leib					echo $prefix . str_repeat(DOKU_TAB, $level*2-1) . '</li>'.NL;
484602dcfebSsaschaleib					$level--;
485602dcfebSsaschaleib				}
486e5d0cb92SSascha Leib			} else {
4875dd187b0SSascha Leib				echo '</li>'.NL;
488e5d0cb92SSascha Leib			}
489e5d0cb92SSascha Leib
490d65dddeeSsaschaleib			$href = ( array_key_exists('link', $it ) ? $it['link'] : '' ) . ( array_key_exists('hid', $it) && $it['hid'] !== '' ? '#' . $it['hid'] : '' );
491a3608ff1SSascha Leib
4925dd187b0SSascha Leib			echo $prefix . str_repeat(DOKU_TAB, $nl*2 + 1) . '<li role="presentation">' . "<a role=\"menuitem\" href=\"{$href}\">" . htmlentities($it['title']) . '</a>';
493e5d0cb92SSascha Leib			$level = $nl;
494e5d0cb92SSascha Leib		}
495e5d0cb92SSascha Leib
496e5d0cb92SSascha Leib		for ($i = $level-1; $i > 0; $i--) {
4975dd187b0SSascha Leib			echo '</li>'.NL;
4985dd187b0SSascha Leib			echo $prefix . str_repeat(DOKU_TAB, $i*2 + 1) . '</ol>';
499e5d0cb92SSascha Leib		}
500e5d0cb92SSascha Leib
5015dd187b0SSascha Leib		echo '</li>'.NL;
5025dd187b0SSascha Leib		echo $prefix . DOKU_TAB . DOKU_TAB . '</ol>'.NL;
5035dd187b0SSascha Leib		echo $prefix . DOKU_TAB . '</nav>'.NL;
5045dd187b0SSascha Leib		echo $prefix . '</aside>'.NL;
505e5d0cb92SSascha Leib	}
506e5d0cb92SSascha Leib}
507e5d0cb92SSascha Leib
508e5d0cb92SSascha Leib/**
509e5d0cb92SSascha Leib * Print last change date
510e5d0cb92SSascha Leib *
511e5d0cb92SSascha Leib * @author Sascha Leib <sascha@leib.be>
512e5d0cb92SSascha Leib *
513e5d0cb92SSascha Leib * @param  string $prefix to be added before each line
514e5d0cb92SSascha Leib *
515e5d0cb92SSascha Leib * @return void
516e5d0cb92SSascha Leib */
517e5d0cb92SSascha Leibfunction my_lastchange($prefix = '') {
518e5d0cb92SSascha Leib
519e5d0cb92SSascha Leib	global $lang;
520e5d0cb92SSascha Leib	global $INFO;
521ee4968b1Ssaschaleib	global $conf;
522286fa030SSascha Leib	global $_REQUEST;
523e5d0cb92SSascha Leib
524ee4968b1Ssaschaleib	$lastmod = $INFO['lastmod'];
525286fa030SSascha Leib	$doAdmin = (array_key_exists('do', $_REQUEST) && $_REQUEST['do'] == 'admin');
526e5d0cb92SSascha Leib
527286fa030SSascha Leib	if (!$doAdmin && intval($lastmod) > 0) { // is valid date?
528e5d0cb92SSascha Leib
529b24bd7bbSsaschaleib		$longDate = htmlentities(dformat($lastmod));
530b24bd7bbSsaschaleib
5315dd187b0SSascha Leib		echo $prefix . '<p class="docInfo">'.NL;
5325dd187b0SSascha Leib		echo $prefix . DOKU_TAB . '<bdi>' . $lang['lastmod'] . '</bdi>'.NL;
5335dd187b0SSascha Leib		echo $prefix . DOKU_TAB . '<time datetime="' . date('c', $lastmod) . '" title="' . $longDate . '"><span class="print-only">' . $longDate . '</span><span class="noprint">' . datetime_h($lastmod) . "</span></time>".NL;
5345dd187b0SSascha Leib		echo $prefix . '</p>'.NL;
535ee4968b1Ssaschaleib	}
536e5d0cb92SSascha Leib
537e5d0cb92SSascha Leib	/* user name for last change (is this really interesting to the visitor?) */
5385dd187b0SSascha Leib	/* echo $prefix .'<span class="editorname" tabindex="0">' . $lang['by'] . ' <bdi>' . editorinfo($INFO['editor']) . '</bdi></span>'.NL; */
539e5d0cb92SSascha Leib}
540e5d0cb92SSascha Leib
541e5d0cb92SSascha Leib/**
542e5d0cb92SSascha Leib * Returns a description list of the metatags of the current image
543e5d0cb92SSascha Leib *
544e5d0cb92SSascha Leib * @return string html of description list
545e5d0cb92SSascha Leib */
546e5d0cb92SSascha Leibfunction my_img_meta($prefix = '') {
547e5d0cb92SSascha Leib	global $lang;
548e5d0cb92SSascha Leib
549e5d0cb92SSascha Leib	$format = '%Y-%m-%dT%T%z';	/* e.g. 2021-21-05T16:45:12+02:00 */
550e5d0cb92SSascha Leib
551e5d0cb92SSascha Leib	$tags = tpl_get_img_meta();
552e5d0cb92SSascha Leib
553e5d0cb92SSascha Leib	foreach($tags as $tag) {
554e5d0cb92SSascha Leib		$label = $lang[$tag['langkey']];
555e5d0cb92SSascha Leib		if(!$label) $label = $tag['langkey'] . ':';
556e5d0cb92SSascha Leib
5575dd187b0SSascha Leib		echo $prefix . "<tr><th>{$label}</th><td>";
558e5d0cb92SSascha Leib		if ($tag['type'] == 'date') {
559e5d0cb92SSascha Leib			echo '<time datetime="' . strftime($format, $tag['value']) . '">' . dformat($tag['value']) . '</time>';
560e5d0cb92SSascha Leib		} else {
561e5d0cb92SSascha Leib			echo hsc($tag['value']);
562e5d0cb92SSascha Leib		}
5635dd187b0SSascha Leib		echo '</td></tr>'.NL;
564e5d0cb92SSascha Leib	}
565e5d0cb92SSascha Leib}
566e5d0cb92SSascha Leib
567e5d0cb92SSascha Leib/**
568e5d0cb92SSascha Leib * Creates the Site logo image link
569e5d0cb92SSascha Leib *
570e5d0cb92SSascha Leib */
571e5d0cb92SSascha Leibfunction my_sitelogo() {
572e5d0cb92SSascha Leib	global $conf;
573e5d0cb92SSascha Leib
574e5d0cb92SSascha Leib	// get logo either out of the template images folder or data/media folder
575e5d0cb92SSascha Leib	$logoSize = array();
576e5d0cb92SSascha Leib	$logo = tpl_getMediaFile(array(':logo.svg', ':wiki:logo.svg', ':logo.png', ':wiki:logo.png', 'images/sitelogo.svg'), false, $logoSize);
57776a91b98Ssaschaleib	tpl_link( my_homelink(),
5785dd187b0SSascha Leib		"<img src=\"{$logo}\" " . (is_array($logoSize) && array_key_exists(3, $logoSize) ? $logoSize[3] : '') . ' alt="' . htmlentities($conf['title']) . '" />', 'accesskey="h" title="[H]" class="logo"');
579e5d0cb92SSascha Leib}
580e5d0cb92SSascha Leib
581e5d0cb92SSascha Leib/**
582e5d0cb92SSascha Leib * Creates the various favicon and similar links:
583e5d0cb92SSascha Leib *
584e5d0cb92SSascha Leib * @param  string $color overwrite the theme color.
585e5d0cb92SSascha Leib *
586e5d0cb92SSascha Leib * @return null
587e5d0cb92SSascha Leib */
588e5d0cb92SSascha Leibfunction my_favicons($color = null) {
589e5d0cb92SSascha Leib
590e5d0cb92SSascha Leib	$logoSize = array();
591e5d0cb92SSascha Leib
59234d27ad1Ssaschaleib	/* Theme color:
593e5d0cb92SSascha Leib	if ($color == null) {
594e5d0cb92SSascha Leib
59534d27ad1Ssaschaleib		// get the style config:
596e5d0cb92SSascha Leib		$styleUtil = new \dokuwiki\StyleUtils();
597e5d0cb92SSascha Leib		$styleIni = $styleUtil->cssStyleini();
598e5d0cb92SSascha Leib		$replacements = $styleIni['replacements'];
59919b66c8eSSascha Leib		$color = $replacements['__theme_color__'];
600e5d0cb92SSascha Leib
601e5d0cb92SSascha Leib		if ($color== null) { $color = '#2b73b7'; }
602e5d0cb92SSascha Leib	}
6035dd187b0SSascha Leib	echo DOKU_TAB . "<meta name=\"theme-color\" content=\"" . $color . "\" />".NL; */
604e5d0cb92SSascha Leib
605e5d0cb92SSascha Leib	// get the favicon:
606e5d0cb92SSascha Leib	$link = tpl_getMediaFile(array(':favicon.ico', ':favicon.png', ':favicon.svg', ':wiki:favicon.ico', ':wiki:favicon.png', ':wiki:favicon.svg'), false, $logoSize);
6075dd187b0SSascha Leib	echo DOKU_TAB . "<link rel=\"icon\" href=\"{$link}\" />".NL;
608e5d0cb92SSascha Leib
609e5d0cb92SSascha Leib	// Apple Touch Icon
610e5d0cb92SSascha Leib	$logoSize = array();
611e5d0cb92SSascha Leib	$link = tpl_getMediaFile(array(':apple-touch-icon.png', ':wiki:apple-touch-icon.png', 'images/apple-touch-icon.png'), false, $logoSize);
6125dd187b0SSascha Leib	echo DOKU_TAB . "<link rel=\"apple-touch-icon\" href=\"{$link}\" />".NL;
613e5d0cb92SSascha Leib
614e5d0cb92SSascha Leib}
61577c863f3SSascha Leib
61677c863f3SSascha Leib/**
61777c863f3SSascha Leib * inserts the Cookies banner, if appropriate.
61877c863f3SSascha Leib * This is based on Michal Koutny’s "cookielaw" plugin
61977c863f3SSascha Leib *
62077c863f3SSascha Leib * @param  string $prefix to be added before each line
62177c863f3SSascha Leib */
62277c863f3SSascha Leibfunction my_cookiebanner($prefix = '') {
62377c863f3SSascha Leib
62477c863f3SSascha Leib	// get the configuration settings:
62577c863f3SSascha Leib	$msg = tpl_getConf('cookiemsg', '(no message configured)');
62677c863f3SSascha Leib	$position = tpl_getConf('cookiepos', 'bottom');
62777c863f3SSascha Leib	$link = tpl_getConf('cookielink', 'about:cookies');
62877c863f3SSascha Leib
6299c4ee6d7STim Kuhlbusch	// if the cookie is already set or position is set to hide, do nothing.
6309c4ee6d7STim Kuhlbusch	if ( isset($_COOKIE['cookielaw']) or $position == 'hide') {
6319c4ee6d7STim Kuhlbusch		return;
6329c4ee6d7STim Kuhlbusch	}
6339c4ee6d7STim Kuhlbusch
6345dd187b0SSascha Leib	// define the cookie icon:
6355dd187b0SSascha Leib	$svg = '<svg width="100%" height="100%" viewBox="0 0 64 64" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:1.5;"><path d="M17.272,19.443c6.035,-0.582 10.759,-5.673 10.759,-11.858c-0,-1.843 -0.42,-3.588 -1.168,-5.146c1.668,-0.289 3.385,-0.439 5.137,-0.439c16.557,-0 30,13.443 30,30c0,16.557 -13.443,30 -30,30c-16.557,-0 -30,-13.443 -30,-30c0,-0.925 0.042,-1.84 0.124,-2.743c1.061,0.31 2.183,0.476 3.345,0.476c6.025,0 11.011,-4.482 11.803,-10.29Z" style="fill:#d5944b;stroke:#26251d;stroke-width:4px;"/><circle cx="17.927" cy="41.07" r="3.488" style="fill:#443017;"/><circle cx="31.33" cy="30.835" r="3.488" style="fill:#443017;"/><circle cx="32" cy="49.883" r="3.488" style="fill:#443017;"/><circle cx="43.952" cy="41.07" r="3.488" style="fill:#443017;"/><circle cx="49.092" cy="27.347" r="3.488" style="fill:#443017;"/><circle cx="38.306" cy="16.056" r="3.488" style="fill:#443017;"/></svg>';
6365dd187b0SSascha Leib
63777c863f3SSascha Leib	// output the HTML code:
6385dd187b0SSascha Leib	echo $prefix . "<div id=\"cookiebanner\" class=\"cb_{$position}\">".NL;
6395dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<p class="cb_info">'.NL;
6405dd187b0SSascha Leib	echo $prefix . DOKU_TAB . DOKU_TAB . "<span class=\"cb_icon\">{$svg}</span>".NL;
6415dd187b0SSascha Leib	echo $prefix . DOKU_TAB . DOKU_TAB . "<span class=\"cb_msg\">{$msg}</span>".NL;
6425dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '</p>'.NL;
6435dd187b0SSascha Leib	echo $prefix . DOKU_TAB . '<p class="cb_action">'.NL;
6445dd187b0SSascha Leib	echo $prefix . DOKU_TAB . DOKU_TAB . '<button>' . hsc(tpl_getLang('cookie_consent')) . '</button>'.NL;
6455dd187b0SSascha Leib	echo $prefix . DOKU_TAB . DOKU_TAB;
64677c863f3SSascha Leib	if ( substr($link, 0, 7) == 'http://' || substr($link, 0, 8) == 'https://') {
6475dd187b0SSascha Leib		echo "<a href=\"{$link}\" target=\"_blank\">" . hsc(tpl_getLang('cookie_linktext')) . '</a>';
64877c863f3SSascha Leib	} else {
64977c863f3SSascha Leib		tpl_pagelink($link, tpl_getLang('cookie_linktext'));
65077c863f3SSascha Leib	}
6515dd187b0SSascha Leib	echo $prefix . DOKU_LF . DOKU_TAB.'</p>'.NL;
6525dd187b0SSascha Leib	echo $prefix . '</div>'.NL;
65377c863f3SSascha Leib
65477c863f3SSascha Leib}
655764c430fSSascha Leib
656764c430fSSascha Leib/**
657764c430fSSascha Leib * inserts the Languages menu, if appropriate.
658764c430fSSascha Leib *
659764c430fSSascha Leib * @author Sascha Leib <sascha@leib.be>
660200aa3d2SSascha Leib * @author Andreas Gohr <andi@splitbrain.org>
661764c430fSSascha Leib *
662764c430fSSascha Leib * @param  string $prefix to be added before each line
663200aa3d2SSascha Leib * @param  string $place the location from where it is called
664200aa3d2SSascha Leib * @param  string $checkage should the age of the translation be checked?
665764c430fSSascha Leib */
666200aa3d2SSascha Leibfunction my_langmenu($prefix, $place, $checkage = true) {
667200aa3d2SSascha Leib
668200aa3d2SSascha Leib	global $INFO;
669200aa3d2SSascha Leib	global $conf;
670200aa3d2SSascha Leib
671200aa3d2SSascha Leib	// the current page language:
672200aa3d2SSascha Leib	$lang = $conf['lang'];
673764c430fSSascha Leib
674764c430fSSascha Leib	/* get the config option: */
675764c430fSSascha Leib	$config = tpl_getConf('langmenu', 'none');
676764c430fSSascha Leib
677dcb5c54eSSascha Leib	/* only shw the menu if this is called from the right place */
678dcb5c54eSSascha Leib	if ($config == $place) {
679dcb5c54eSSascha Leib
680200aa3d2SSascha Leib		/* collect the output: */
681200aa3d2SSascha Leib		$out = '';
682200aa3d2SSascha Leib
683dcb5c54eSSascha Leib		/* try to load the plugin: */
684200aa3d2SSascha Leib		$trans = plugin_load('helper','translation');
685dcb5c54eSSascha Leib
686dcb5c54eSSascha Leib		/* plugin available? */
687200aa3d2SSascha Leib		if ($trans) {
688200aa3d2SSascha Leib
689200aa3d2SSascha Leib			if (!$trans->istranslatable($INFO['id'])) return '';
690200aa3d2SSascha Leib			if ($checkage) $trans->checkage();
691200aa3d2SSascha Leib
692200aa3d2SSascha Leib			[, $idpart] = $trans->getTransParts($INFO['id']);
693200aa3d2SSascha Leib
694200aa3d2SSascha Leib			$asMenu = ($place == 'tb'); // display as menu only in toolbar!
695200aa3d2SSascha Leib
6965dd187b0SSascha Leib			$out .= $prefix . "<div id=\"{$place}Languages\">".NL;
697200aa3d2SSascha Leib
698200aa3d2SSascha Leib			// create the header item
699200aa3d2SSascha Leib
700dcb5c54eSSascha Leib			if ($asMenu) { // show as menu (toolbar)
701200aa3d2SSascha Leib
702dcb5c54eSSascha Leib				// get the language name (in the local language)
703200aa3d2SSascha Leib				$langName = htmlentities($trans->getLocalName($lang));
704*4c55f691SSascha Leib				$langId = substr($lang, 0, 2);
705200aa3d2SSascha Leib
706dcb5c54eSSascha Leib				/* prepare the menu icon (note that the language code and name are embedded! */
707*4c55f691SSascha Leib				$svg = "<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><title>{$langName}</title><path d='M20,2H4A2,2 0 0,0 2,4V22L6,18H20A2,2 0 0,0 22,16V4C22,2.89 21.1,2 20,2Z' /><text lengthAdjust='spacingAndGlyphs' x='50%' y='47%' dominant-baseline='middle' text-anchor='middle' style='font-size:50%'>{$langId}</text></svg>";
708200aa3d2SSascha Leib
709dcb5c54eSSascha Leib				// prepare the menu button:
7105dd187b0SSascha Leib				$out .= $prefix . DOKU_TAB . '<button id="langButton" aria-haspopup="menu" aria-controls="langMenuWrapper" aria-expanded="false">'.NL;
7115dd187b0SSascha Leib				$out .= $prefix . DOKU_TAB . DOKU_TAB . $svg . NL;
7125dd187b0SSascha Leib				$out .= $prefix . DOKU_TAB . DOKU_TAB . '<span class="sronly">' . $trans->getLang('translations') . '</span>'.NL;
7135dd187b0SSascha Leib				$out .= $prefix . DOKU_TAB . '</button>'.NL;
714200aa3d2SSascha Leib
715dcb5c54eSSascha Leib			} else { // show as list (sidebar)
716200aa3d2SSascha Leib
717dcb5c54eSSascha Leib				// show title (only if the option is configured)
718200aa3d2SSascha Leib				if (isset($trans->opts['title'])) {
719200aa3d2SSascha Leib
720dcb5c54eSSascha Leib					// get a localized headline text
721dcb5c54eSSascha Leib					$headline = tpl_getLang('languages');
722dcb5c54eSSascha Leib
723dcb5c54eSSascha Leib					// should a link to the about page be added?
724dcb5c54eSSascha Leib					$about = $trans->getConf('about'); /* get the about link */
725dcb5c54eSSascha Leib					if ($about !== '') {
726dcb5c54eSSascha Leib						/* localized about links? */
727dcb5c54eSSascha Leib						if ($trans->getConf('localabout')) {
728dcb5c54eSSascha Leib							[, $aboutid] = $trans->getTransParts($about);
729dcb5c54eSSascha Leib							[$about, ] = $trans->buildTransID($lang, $aboutid);
730dcb5c54eSSascha Leib							$about = cleanID($about);
731764c430fSSascha Leib						}
732dcb5c54eSSascha Leib						// build the link:
733dcb5c54eSSascha Leib						$headline = html_wikilink($about, $headline);
734dcb5c54eSSascha Leib					}
735dcb5c54eSSascha Leib					/* complete the headline */
7365dd187b0SSascha Leib					$out .= $prefix . DOKU_TAB . "<h3><span>{$headline}</span></h3>".NL;
737200aa3d2SSascha Leib				}
738200aa3d2SSascha Leib			}
739200aa3d2SSascha Leib
740200aa3d2SSascha Leib			/* build the menu content */
7415dd187b0SSascha Leib			$out .= $prefix . DOKU_TAB . '<div id="langMenu' . ( $asMenu ? 'Wrapper" role="menu" style="display: none"' : 'List"') . '>'.NL;
7425dd187b0SSascha Leib			$out .= $prefix . DOKU_TAB . DOKU_TAB . '<ul id="lang' . ( $asMenu ? 'Menu" role="group"' : 'List"' ) . '>'.NL;
743200aa3d2SSascha Leib
744dcb5c54eSSascha Leib			// loop over each language and add it to the menu:
745200aa3d2SSascha Leib			foreach ($trans->translations as $t) {
746200aa3d2SSascha Leib				$l = ( $t !== '' ? $t : $lang );
747200aa3d2SSascha Leib
748200aa3d2SSascha Leib				[$trg, $lng] = $trans->buildTransID($t, $idpart);
749*4c55f691SSascha Leib				$langName = $trans->getLocalName($lng);
750*4c55f691SSascha Leib				$lngId = substr($lng, 0, 2);
751200aa3d2SSascha Leib				$trg = cleanID($trg);
752200aa3d2SSascha Leib				$exists = page_exists($trg, '', false);
753200aa3d2SSascha Leib				$filter = tpl_getConf('langfilter', 'all');
754200aa3d2SSascha Leib
755dcb5c54eSSascha Leib				/* only show if translation exists? */
756200aa3d2SSascha Leib				if ($exists || $filter === 'all') {
757200aa3d2SSascha Leib					$class = 'wikilink' . ( $exists ? '1' : '2');
758200aa3d2SSascha Leib					$link = wl($trg);
759200aa3d2SSascha Leib					$current = ($lng == $lang);
760200aa3d2SSascha Leib
7615dd187b0SSascha Leib					$out .= $prefix . DOKU_TAB . DOKU_TAB . DOKU_TAB .'<li' . ( $asMenu ? ' role="presentation"' : '' ). ( $current ? ' class="current"' : '' ) . '>'.NL;
762*4c55f691SSascha Leib					$out .= $prefix . DOKU_TAB . DOKU_TAB . DOKU_TAB . DOKU_TAB . "<a href=\"{$link}\" hreflang=\"{$lngId}\" class=\"{$class}\"" . ( $asMenu ? ' role="menuitem"' : '' ) . "><bdi lang=\"{$lngId}\">{$langName}</bdi></a>".NL;
7635dd187b0SSascha Leib					$out .= $prefix . DOKU_TAB . DOKU_TAB . DOKU_TAB . '</li>'.NL;
764200aa3d2SSascha Leib				}
765200aa3d2SSascha Leib			}
766200aa3d2SSascha Leib
767dcb5c54eSSascha Leib			// close all open elements:
7685dd187b0SSascha Leib			$out .= $prefix . DOKU_TAB . DOKU_TAB . '</ul>'.NL
7695dd187b0SSascha Leib				 .	$prefix . DOKU_TAB . '</div>'.NL
7705dd187b0SSascha Leib				 .	$prefix . '</div>'.NL;
771200aa3d2SSascha Leib		}
772dcb5c54eSSascha Leib		echo $out; // done.
773200aa3d2SSascha Leib	}
774764c430fSSascha Leib}