xref: /dokuwiki/inc/template.php (revision 01f9be51e2f5b61e20deb8f9c92eccb62fa12a17)
16b13307fSandi<?php
26b13307fSandi/**
36b13307fSandi * DokuWiki template functions
46b13307fSandi *
56b13307fSandi * @license    GPL 2 (http://www.gnu.org/licenses/gpl.html)
66b13307fSandi * @author     Andreas Gohr <andi@splitbrain.org>
76b13307fSandi */
86b13307fSandi
9fa8adffeSAndreas Gohrif(!defined('DOKU_INC')) die('meh.');
106b13307fSandi
116b13307fSandi/**
12ac7a515fSAndreas Gohr * Access a template file
13ac7a515fSAndreas Gohr *
14ac7a515fSAndreas Gohr * Returns the path to the given file inside the current template, uses
15ac7a515fSAndreas Gohr * default template if the custom version doesn't exist.
165a892029SAndreas Gohr *
175a892029SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
18ac7a515fSAndreas Gohr * @param string $file
19ac7a515fSAndreas Gohr * @return string
205a892029SAndreas Gohr */
21ac7a515fSAndreas Gohrfunction template($file) {
225a892029SAndreas Gohr    global $conf;
235a892029SAndreas Gohr
24ac7a515fSAndreas Gohr    if(@is_readable(DOKU_INC.'lib/tpl/'.$conf['template'].'/'.$file))
25ac7a515fSAndreas Gohr        return DOKU_INC.'lib/tpl/'.$conf['template'].'/'.$file;
265a892029SAndreas Gohr
27ac7a515fSAndreas Gohr    return DOKU_INC.'lib/tpl/dokuwiki/'.$file;
285a892029SAndreas Gohr}
295a892029SAndreas Gohr
30c4766956SAndreas Gohr/**
31c4766956SAndreas Gohr * Convenience function to access template dir from local FS
32c4766956SAndreas Gohr *
33c4766956SAndreas Gohr * This replaces the deprecated DOKU_TPLINC constant
34c4766956SAndreas Gohr *
35c4766956SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
36afb2c082SAndreas Gohr * @param string $tpl The template to use, default to current one
37ac7a515fSAndreas Gohr * @return string
38c4766956SAndreas Gohr */
39afb2c082SAndreas Gohrfunction tpl_incdir($tpl='') {
4075b14482SAndreas Gohr    global $conf;
41afb2c082SAndreas Gohr    if(!$tpl) $tpl = $conf['template'];
42afb2c082SAndreas Gohr    return DOKU_INC.'lib/tpl/'.$tpl.'/';
43c4766956SAndreas Gohr}
44c4766956SAndreas Gohr
45c4766956SAndreas Gohr/**
46c4766956SAndreas Gohr * Convenience function to access template dir from web
47c4766956SAndreas Gohr *
48c4766956SAndreas Gohr * This replaces the deprecated DOKU_TPL constant
49c4766956SAndreas Gohr *
50c4766956SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
51afb2c082SAndreas Gohr * @param string $tpl The template to use, default to current one
52ac7a515fSAndreas Gohr * @return string
53c4766956SAndreas Gohr */
5499dca513SAndreas Gohrfunction tpl_basedir($tpl='') {
5575b14482SAndreas Gohr    global $conf;
56afb2c082SAndreas Gohr    if(!$tpl) $tpl = $conf['template'];
57dcd4911eSMichael Hamann    return DOKU_BASE.'lib/tpl/'.$tpl.'/';
58c4766956SAndreas Gohr}
59c4766956SAndreas Gohr
605a892029SAndreas Gohr/**
616b13307fSandi * Print the content
626b13307fSandi *
636b13307fSandi * This function is used for printing all the usual content
646b13307fSandi * (defined by the global $ACT var) by calling the appropriate
656b13307fSandi * outputfunction(s) from html.php
666b13307fSandi *
67ee4c4a1bSAndreas Gohr * Everything that doesn't use the main template file isn't
68ee4c4a1bSAndreas Gohr * handled by this function. ACL stuff is not done here either.
696b13307fSandi *
706b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
71ac7a515fSAndreas Gohr * @triggers TPL_ACT_RENDER
72ac7a515fSAndreas Gohr * @triggers TPL_CONTENT_DISPLAY
73ac7a515fSAndreas Gohr * @param bool $prependTOC should the TOC be displayed here?
74ac7a515fSAndreas Gohr * @return bool true if any output
756b13307fSandi */
76b8595a66SAndreas Gohrfunction tpl_content($prependTOC = true) {
777ea0913cSchris    global $ACT;
78b8595a66SAndreas Gohr    global $INFO;
79b8595a66SAndreas Gohr    $INFO['prependTOC'] = $prependTOC;
807ea0913cSchris
817ea0913cSchris    ob_start();
82746855cfSBen Coburn    trigger_event('TPL_ACT_RENDER', $ACT, 'tpl_content_core');
837ea0913cSchris    $html_output = ob_get_clean();
84746855cfSBen Coburn    trigger_event('TPL_CONTENT_DISPLAY', $html_output, 'ptln');
8554e95700STom N Harris
8654e95700STom N Harris    return !empty($html_output);
877ea0913cSchris}
887ea0913cSchris
89ac7a515fSAndreas Gohr/**
90ac7a515fSAndreas Gohr * Default Action of TPL_ACT_RENDER
91ac7a515fSAndreas Gohr *
92ac7a515fSAndreas Gohr * @return bool
93ac7a515fSAndreas Gohr */
947ea0913cSchrisfunction tpl_content_core() {
956b13307fSandi    global $ACT;
966b13307fSandi    global $TEXT;
976b13307fSandi    global $PRE;
986b13307fSandi    global $SUF;
996b13307fSandi    global $SUM;
1006b13307fSandi    global $IDX;
101ac7a515fSAndreas Gohr    global $INPUT;
1026b13307fSandi
1036b13307fSandi    switch($ACT) {
1046b13307fSandi        case 'show':
1056b13307fSandi            html_show();
1066b13307fSandi            break;
107ac7a515fSAndreas Gohr        /** @noinspection PhpMissingBreakStatementInspection */
10845a99335SAdrian Lang        case 'locked':
10945a99335SAdrian Lang            html_locked();
1106b13307fSandi        case 'edit':
11145a99335SAdrian Lang        case 'recover':
1126b13307fSandi            html_edit();
1136b13307fSandi            break;
11445a99335SAdrian Lang        case 'preview':
11545a99335SAdrian Lang            html_edit();
11645a99335SAdrian Lang            html_show($TEXT);
11745a99335SAdrian Lang            break;
118ee4c4a1bSAndreas Gohr        case 'draft':
119ee4c4a1bSAndreas Gohr            html_draft();
120ee4c4a1bSAndreas Gohr            break;
1216b13307fSandi        case 'search':
1226b13307fSandi            html_search();
1236b13307fSandi            break;
1246b13307fSandi        case 'revisions':
125ac7a515fSAndreas Gohr            html_revisions($INPUT->int('first'));
1266b13307fSandi            break;
1276b13307fSandi        case 'diff':
1286b13307fSandi            html_diff();
1296b13307fSandi            break;
1306b13307fSandi        case 'recent':
1313c94d07bSAnika Henke            $show_changes = $INPUT->str('show_changes');
1323c94d07bSAnika Henke            if (empty($show_changes)) {
1333c94d07bSAnika Henke                $show_changes = get_doku_pref('show_changes', $show_changes);
1343c94d07bSAnika Henke            }
1353c94d07bSAnika Henke            html_recent($INPUT->extract('first')->int('first'), $show_changes);
1366b13307fSandi            break;
1376b13307fSandi        case 'index':
1386b13307fSandi            html_index($IDX); #FIXME can this be pulled from globals? is it sanitized correctly?
1396b13307fSandi            break;
1406b13307fSandi        case 'backlink':
1416b13307fSandi            html_backlinks();
1426b13307fSandi            break;
1436b13307fSandi        case 'conflict':
1446b13307fSandi            html_conflict(con($PRE, $TEXT, $SUF), $SUM);
1456b13307fSandi            html_diff(con($PRE, $TEXT, $SUF), false);
1466b13307fSandi            break;
1476b13307fSandi        case 'login':
1486b13307fSandi            html_login();
1496b13307fSandi            break;
1506b13307fSandi        case 'register':
1516b13307fSandi            html_register();
1526b13307fSandi            break;
1538b06d178Schris        case 'resendpwd':
1548b06d178Schris            html_resendpwd();
1558b06d178Schris            break;
156820fa24bSandi        case 'denied':
1572f2c518cSGerrit Uitslag            html_denied();
158820fa24bSandi            break;
1598b06d178Schris        case 'profile' :
1608b06d178Schris            html_updateprofile();
1618b06d178Schris            break;
162c19fe9c0Sandi        case 'admin':
163c19fe9c0Sandi            tpl_admin();
164c19fe9c0Sandi            break;
1655b75cd1fSAdrian Lang        case 'subscribe':
1665b75cd1fSAdrian Lang            tpl_subscribe();
1675b75cd1fSAdrian Lang            break;
168d9162c6cSKate Arzamastseva        case 'media':
169d9162c6cSKate Arzamastseva            tpl_media();
170d9162c6cSKate Arzamastseva            break;
1716b13307fSandi        default:
17224bb549bSchris            $evt = new Doku_Event('TPL_ACT_UNKNOWN', $ACT);
17324bb549bSchris            if($evt->advise_before())
174ea67f144Sandi                msg("Failed to handle command: ".hsc($ACT), -1);
17524bb549bSchris            $evt->advise_after();
17624bb549bSchris            unset($evt);
17754e95700STom N Harris            return false;
1786b13307fSandi    }
17954e95700STom N Harris    return true;
1806b13307fSandi}
1816b13307fSandi
182c19fe9c0Sandi/**
183b8595a66SAndreas Gohr * Places the TOC where the function is called
184b8595a66SAndreas Gohr *
185b8595a66SAndreas Gohr * If you use this you most probably want to call tpl_content with
186b8595a66SAndreas Gohr * a false argument
187b8595a66SAndreas Gohr *
188b8595a66SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
189ac7a515fSAndreas Gohr * @param bool $return Should the TOC be returned instead to be printed?
190ac7a515fSAndreas Gohr * @return string
191b8595a66SAndreas Gohr */
192b8595a66SAndreas Gohrfunction tpl_toc($return = false) {
193b8595a66SAndreas Gohr    global $TOC;
194b8595a66SAndreas Gohr    global $ACT;
195b8595a66SAndreas Gohr    global $ID;
196b8595a66SAndreas Gohr    global $REV;
197b8595a66SAndreas Gohr    global $INFO;
198851f2e89SAnika Henke    global $conf;
199ac7a515fSAndreas Gohr    global $INPUT;
200b8595a66SAndreas Gohr    $toc = array();
201b8595a66SAndreas Gohr
202b8595a66SAndreas Gohr    if(is_array($TOC)) {
203b8595a66SAndreas Gohr        // if a TOC was prepared in global scope, always use it
204b8595a66SAndreas Gohr        $toc = $TOC;
2053c86d7c9SAndreas Gohr    } elseif(($ACT == 'show' || substr($ACT, 0, 6) == 'export') && !$REV && $INFO['exists']) {
206b8595a66SAndreas Gohr        // get TOC from metadata, render if neccessary
20765aa8490SMichael Hamann        $meta = p_get_metadata($ID, false, METADATA_RENDER_USING_CACHE);
208b8595a66SAndreas Gohr        if(isset($meta['internal']['toc'])) {
209b8595a66SAndreas Gohr            $tocok = $meta['internal']['toc'];
210b8595a66SAndreas Gohr        } else {
2112bb0d541Schris            $tocok = true;
212b8595a66SAndreas Gohr        }
213f87b5dbbSChristopher Smith        $toc = isset($meta['description']['tableofcontents']) ? $meta['description']['tableofcontents'] : null;
214851f2e89SAnika Henke        if(!$tocok || !is_array($toc) || !$conf['tocminheads'] || count($toc) < $conf['tocminheads']) {
215b8595a66SAndreas Gohr            $toc = array();
216b8595a66SAndreas Gohr        }
217b8595a66SAndreas Gohr    } elseif($ACT == 'admin') {
218b8595a66SAndreas Gohr        // try to load admin plugin TOC FIXME: duplicates code from tpl_admin
219b8595a66SAndreas Gohr        $plugin = null;
220ac7a515fSAndreas Gohr        $class  = $INPUT->str('page');
221ac7a515fSAndreas Gohr        if(!empty($class)) {
222b8595a66SAndreas Gohr            $pluginlist = plugin_list('admin');
223ac7a515fSAndreas Gohr            if(in_array($class, $pluginlist)) {
224b8595a66SAndreas Gohr                // attempt to load the plugin
225ac7a515fSAndreas Gohr                /** @var $plugin DokuWiki_Admin_Plugin */
226a04f2bd5SGerrit Uitslag                $plugin = plugin_load('admin', $class);
227b8595a66SAndreas Gohr            }
228b8595a66SAndreas Gohr        }
229ac7a515fSAndreas Gohr        if( ($plugin !== null) && (!$plugin->forAdminOnly() || $INFO['isadmin']) ) {
230b8595a66SAndreas Gohr            $toc = $plugin->getTOC();
231b8595a66SAndreas Gohr            $TOC = $toc; // avoid later rebuild
232b8595a66SAndreas Gohr        }
233b8595a66SAndreas Gohr    }
234b8595a66SAndreas Gohr
2350b17fdc6SAndreas Gohr    trigger_event('TPL_TOC_RENDER', $toc, null, false);
236b8595a66SAndreas Gohr    $html = html_TOC($toc);
237b8595a66SAndreas Gohr    if($return) return $html;
238b8595a66SAndreas Gohr    echo $html;
239ac7a515fSAndreas Gohr    return '';
240b8595a66SAndreas Gohr}
241b8595a66SAndreas Gohr
242b8595a66SAndreas Gohr/**
243c19fe9c0Sandi * Handle the admin page contents
244c19fe9c0Sandi *
245c19fe9c0Sandi * @author Andreas Gohr <andi@splitbrain.org>
246c19fe9c0Sandi */
247c19fe9c0Sandifunction tpl_admin() {
248f8cc712eSAndreas Gohr    global $INFO;
249b8595a66SAndreas Gohr    global $TOC;
250ac7a515fSAndreas Gohr    global $INPUT;
25111e2ce22Schris
252b8595a66SAndreas Gohr    $plugin = null;
253ac7a515fSAndreas Gohr    $class  = $INPUT->str('page');
254ac7a515fSAndreas Gohr    if(!empty($class)) {
25511e2ce22Schris        $pluginlist = plugin_list('admin');
25611e2ce22Schris
257ac7a515fSAndreas Gohr        if(in_array($class, $pluginlist)) {
25811e2ce22Schris            // attempt to load the plugin
259ac7a515fSAndreas Gohr            /** @var $plugin DokuWiki_Admin_Plugin */
260a04f2bd5SGerrit Uitslag            $plugin = plugin_load('admin', $class);
26111e2ce22Schris        }
26211e2ce22Schris    }
26311e2ce22Schris
264b8595a66SAndreas Gohr    if($plugin !== null) {
265b8595a66SAndreas Gohr        if(!is_array($TOC)) $TOC = $plugin->getTOC(); //if TOC wasn't requested yet
266b8595a66SAndreas Gohr        if($INFO['prependTOC']) tpl_toc();
267f8cc712eSAndreas Gohr        $plugin->html();
268f8cc712eSAndreas Gohr    } else {
269f8cc712eSAndreas Gohr        html_admin();
270f8cc712eSAndreas Gohr    }
27154e95700STom N Harris    return true;
272c19fe9c0Sandi}
2736b13307fSandi
2746b13307fSandi/**
2756b13307fSandi * Print the correct HTML meta headers
2766b13307fSandi *
2776b13307fSandi * This has to go into the head section of your template.
2786b13307fSandi *
2796b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
280ac7a515fSAndreas Gohr * @triggers TPL_METAHEADER_OUTPUT
281ac7a515fSAndreas Gohr * @param  bool $alt Should feeds and alternative format links be added?
282ac7a515fSAndreas Gohr * @return bool
2836b13307fSandi */
284f96fa415SAndreas Gohrfunction tpl_metaheaders($alt = true) {
2856b13307fSandi    global $ID;
286d98d4540SBen Coburn    global $REV;
2876b13307fSandi    global $INFO;
28872e0dc37SAndreas Gohr    global $JSINFO;
2896b13307fSandi    global $ACT;
2904bb1b5aeSAndreas Gohr    global $QUERY;
2916b13307fSandi    global $lang;
292dc57ef04Sandi    global $conf;
2939c438d6cSMichael Hamann    global $updateVersion;
294585bf44eSChristopher Smith    /** @var Input $INPUT */
295585bf44eSChristopher Smith    global $INPUT;
2966b13307fSandi
2977bff22c0SAndreas Gohr    // prepare the head array
2987bff22c0SAndreas Gohr    $head = array();
2997bff22c0SAndreas Gohr
300202ac28bSMichael Klier    // prepare seed for js and css
301cd997f93SAndreas Gohr    $tseed   = $updateVersion;
302202ac28bSMichael Klier    $depends = getConfigFiles('main');
303cd997f93SAndreas Gohr    foreach($depends as $f) $tseed .= @filemtime($f);
304cd997f93SAndreas Gohr    $tseed   = md5($tseed);
3057bff22c0SAndreas Gohr
3066b13307fSandi    // the usual stuff
3073f803e5eSGina Haeussge    $head['meta'][] = array('name'=> 'generator', 'content'=> 'DokuWiki');
308ac7a515fSAndreas Gohr    $head['link'][] = array(
309ac7a515fSAndreas Gohr        'rel' => 'search', 'type'=> 'application/opensearchdescription+xml',
310ac7a515fSAndreas Gohr        'href'=> DOKU_BASE.'lib/exe/opensearch.php', 'title'=> $conf['title']
311ac7a515fSAndreas Gohr    );
312f4f47358SBen Coburn    $head['link'][] = array('rel'=> 'start', 'href'=> DOKU_BASE);
3137aedde2eSGina Haeussge    if(actionOK('index')) {
314ac7a515fSAndreas Gohr        $head['link'][] = array(
315ac7a515fSAndreas Gohr            'rel'  => 'contents', 'href'=> wl($ID, 'do=index', false, '&'),
316ac7a515fSAndreas Gohr            'title'=> $lang['btn_index']
317ac7a515fSAndreas Gohr        );
3187aedde2eSGina Haeussge    }
319f96fa415SAndreas Gohr
320f96fa415SAndreas Gohr    if($alt) {
32154be1338SGerrit Uitslag        if(actionOK('rss')) {
322ac7a515fSAndreas Gohr            $head['link'][] = array(
323ac7a515fSAndreas Gohr                'rel'  => 'alternate', 'type'=> 'application/rss+xml',
324a1288caeSGerrit Uitslag                'title'=> $lang['btn_recent'], 'href'=> DOKU_BASE.'feed.php'
325ac7a515fSAndreas Gohr            );
326ac7a515fSAndreas Gohr            $head['link'][] = array(
327ac7a515fSAndreas Gohr                'rel'  => 'alternate', 'type'=> 'application/rss+xml',
328a1288caeSGerrit Uitslag                'title'=> $lang['currentns'],
329ac7a515fSAndreas Gohr                'href' => DOKU_BASE.'feed.php?mode=list&ns='.$INFO['namespace']
330ac7a515fSAndreas Gohr            );
33154be1338SGerrit Uitslag        }
332c35f3875SAndreas Gohr        if(($ACT == 'show' || $ACT == 'search') && $INFO['writable']) {
333ac7a515fSAndreas Gohr            $head['link'][] = array(
334ac7a515fSAndreas Gohr                'rel'  => 'edit',
335715bdf1fSAndreas Gohr                'title'=> $lang['btn_edit'],
336ac7a515fSAndreas Gohr                'href' => wl($ID, 'do=edit', false, '&')
337ac7a515fSAndreas Gohr            );
338c35f3875SAndreas Gohr        }
339c35f3875SAndreas Gohr
34054be1338SGerrit Uitslag        if(actionOK('rss') && $ACT == 'search') {
341ac7a515fSAndreas Gohr            $head['link'][] = array(
342ac7a515fSAndreas Gohr                'rel'  => 'alternate', 'type'=> 'application/rss+xml',
343a1288caeSGerrit Uitslag                'title'=> $lang['searchresult'],
344ac7a515fSAndreas Gohr                'href' => DOKU_BASE.'feed.php?mode=search&q='.$QUERY
345ac7a515fSAndreas Gohr            );
3464bb1b5aeSAndreas Gohr        }
347bae36d94SAndreas Gohr
348bae36d94SAndreas Gohr        if(actionOK('export_xhtml')) {
349ac7a515fSAndreas Gohr            $head['link'][] = array(
350a1288caeSGerrit Uitslag                'rel' => 'alternate', 'type'=> 'text/html', 'title'=> $lang['plainhtml'],
351ac7a515fSAndreas Gohr                'href'=> exportlink($ID, 'xhtml', '', false, '&')
352ac7a515fSAndreas Gohr            );
353bae36d94SAndreas Gohr        }
354bae36d94SAndreas Gohr
355bae36d94SAndreas Gohr        if(actionOK('export_raw')) {
356ac7a515fSAndreas Gohr            $head['link'][] = array(
357a1288caeSGerrit Uitslag                'rel' => 'alternate', 'type'=> 'text/plain', 'title'=> $lang['wikimarkup'],
358ac7a515fSAndreas Gohr                'href'=> exportlink($ID, 'raw', '', false, '&')
359ac7a515fSAndreas Gohr            );
360f96fa415SAndreas Gohr        }
361bae36d94SAndreas Gohr    }
3626b13307fSandi
3636b13307fSandi    // setup robot tags apropriate for different modes
3644f2e0004STim Weber    if(($ACT == 'show' || $ACT == 'export_xhtml') && !$REV) {
3656b13307fSandi        if($INFO['exists']) {
3666b13307fSandi            //delay indexing:
3676b13307fSandi            if((time() - $INFO['lastmod']) >= $conf['indexdelay']) {
3687bff22c0SAndreas Gohr                $head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow');
3696b13307fSandi            } else {
3707bff22c0SAndreas Gohr                $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow');
3716b13307fSandi            }
372*01f9be51SAnika Henke            $canonicalUrl = wl($ID, '', true, '&');
373*01f9be51SAnika Henke            if ($ID == $conf['start']) {
374*01f9be51SAnika Henke                $canonicalUrl = DOKU_URL;
375*01f9be51SAnika Henke            }
376*01f9be51SAnika Henke            $head['link'][] = array('rel'=> 'canonical', 'href'=> $canonicalUrl);
3776b13307fSandi        } else {
3787bff22c0SAndreas Gohr            $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,follow');
3796b13307fSandi        }
3807a24876fSAndreas Gohr    } elseif(defined('DOKU_MEDIADETAIL')) {
3817bff22c0SAndreas Gohr        $head['meta'][] = array('name'=> 'robots', 'content'=> 'index,follow');
3826b13307fSandi    } else {
3837bff22c0SAndreas Gohr        $head['meta'][] = array('name'=> 'robots', 'content'=> 'noindex,nofollow');
3846b13307fSandi    }
3856b13307fSandi
386831800b8SAndreas Gohr    // set metadata
387831800b8SAndreas Gohr    if($ACT == 'show' || $ACT == 'export_xhtml') {
388831800b8SAndreas Gohr        // keywords (explicit or implicit)
389bb4866bdSchris        if(!empty($INFO['meta']['subject'])) {
3907bff22c0SAndreas Gohr            $head['meta'][] = array('name'=> 'keywords', 'content'=> join(',', $INFO['meta']['subject']));
391831800b8SAndreas Gohr        } else {
3927bff22c0SAndreas Gohr            $head['meta'][] = array('name'=> 'keywords', 'content'=> str_replace(':', ',', $ID));
393831800b8SAndreas Gohr        }
394831800b8SAndreas Gohr    }
395831800b8SAndreas Gohr
39678a6aeb1SAndreas Gohr    // load stylesheets
397ac7a515fSAndreas Gohr    $head['link'][] = array(
398ac7a515fSAndreas Gohr        'rel' => 'stylesheet', 'type'=> 'text/css',
399ac7a515fSAndreas Gohr        'href'=> DOKU_BASE.'lib/exe/css.php?t='.$conf['template'].'&tseed='.$tseed
400ac7a515fSAndreas Gohr    );
401bad31ae9SAndreas Gohr
4028bbcb611SAndreas Gohr    // make $INFO and other vars available to JavaScripts
403463d4a65SAndreas Gohr    $json   = new JSON();
40472e0dc37SAndreas Gohr    $script = "var NS='".$INFO['namespace']."';";
405585bf44eSChristopher Smith    if($conf['useacl'] && $INPUT->server->str('REMOTE_USER')) {
40672e0dc37SAndreas Gohr        $script .= "var SIG='".toolbar_signature()."';";
407c591aabeSAndreas Gohr    }
40872e0dc37SAndreas Gohr    $script .= 'var JSINFO = '.$json->encode($JSINFO).';';
40985f81679SAdrian Lang    $head['script'][] = array('type'=> 'text/javascript', '_data'=> $script);
4108bbcb611SAndreas Gohr
4118bbcb611SAndreas Gohr    // load external javascript
412ac7a515fSAndreas Gohr    $head['script'][] = array(
413ac7a515fSAndreas Gohr        'type'=> 'text/javascript', 'charset'=> 'utf-8', '_data'=> '',
414ac7a515fSAndreas Gohr        'src' => DOKU_BASE.'lib/exe/js.php'.'?tseed='.$tseed
415ac7a515fSAndreas Gohr    );
4167bff22c0SAndreas Gohr
4177bff22c0SAndreas Gohr    // trigger event here
418016b6153SAndreas Gohr    trigger_event('TPL_METAHEADER_OUTPUT', $head, '_tpl_metaheaders_action', true);
41954e95700STom N Harris    return true;
4207bff22c0SAndreas Gohr}
4217bff22c0SAndreas Gohr
4227bff22c0SAndreas Gohr/**
4237bff22c0SAndreas Gohr * prints the array build by tpl_metaheaders
4247bff22c0SAndreas Gohr *
4257bff22c0SAndreas Gohr * $data is an array of different header tags. Each tag can have multiple
4267bff22c0SAndreas Gohr * instances. Attributes are given as key value pairs. Values will be HTML
4277bff22c0SAndreas Gohr * encoded automatically so they should be provided as is in the $data array.
4287bff22c0SAndreas Gohr *
4297bff22c0SAndreas Gohr * For tags having a body attribute specify the the body data in the special
4301304d1dbSAndreas Gohr * attribute '_data'. This field will NOT BE ESCAPED automatically.
4317bff22c0SAndreas Gohr *
4327bff22c0SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
4337bff22c0SAndreas Gohr */
4347bff22c0SAndreas Gohrfunction _tpl_metaheaders_action($data) {
4357bff22c0SAndreas Gohr    foreach($data as $tag => $inst) {
4367bff22c0SAndreas Gohr        foreach($inst as $attr) {
4377bff22c0SAndreas Gohr            echo '<', $tag, ' ', buildAttributes($attr);
43826afa874SMikhail I. Izmestev            if(isset($attr['_data']) || $tag == 'script') {
439e226efe1SAndreas Gohr                if($tag == 'script' && $attr['_data'])
44009f791c4SDominik Eckelmann                    $attr['_data'] = "/*<![CDATA[*/".
441e226efe1SAndreas Gohr                        $attr['_data'].
44209f791c4SDominik Eckelmann                        "\n/*!]]>*/";
443e226efe1SAndreas Gohr
4441304d1dbSAndreas Gohr                echo '>', $attr['_data'], '</', $tag, '>';
4457bff22c0SAndreas Gohr            } else {
4467bff22c0SAndreas Gohr                echo '/>';
4477bff22c0SAndreas Gohr            }
4487bff22c0SAndreas Gohr            echo "\n";
4497bff22c0SAndreas Gohr        }
4507bff22c0SAndreas Gohr    }
4516b13307fSandi}
4526b13307fSandi
4536b13307fSandi/**
4546b13307fSandi * Print a link
4556b13307fSandi *
4565e163278SAndreas Gohr * Just builds a link.
4576b13307fSandi *
4586b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
4596b13307fSandi */
4601af98a77SAnika Henkefunction tpl_link($url, $name, $more = '', $return = false) {
46101f17825SAnika Henke    $out = '<a href="'.$url.'" ';
4621af98a77SAnika Henke    if($more) $out .= ' '.$more;
4631af98a77SAnika Henke    $out .= ">$name</a>";
4641af98a77SAnika Henke    if($return) return $out;
4651af98a77SAnika Henke    print $out;
46654e95700STom N Harris    return true;
4676b13307fSandi}
4686b13307fSandi
4696b13307fSandi/**
47055efc227SAndreas Gohr * Prints a link to a WikiPage
47155efc227SAndreas Gohr *
47255efc227SAndreas Gohr * Wrapper around html_wikilink
47355efc227SAndreas Gohr *
47455efc227SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
47555efc227SAndreas Gohr */
4760b17fdc6SAndreas Gohrfunction tpl_pagelink($id, $name = null) {
477d317fb5dSAnika Henke    print '<bdi>'.html_wikilink($id, $name).'</bdi>';
47854e95700STom N Harris    return true;
47955efc227SAndreas Gohr}
48055efc227SAndreas Gohr
48155efc227SAndreas Gohr/**
482a3ec5f4aSmatthiasgrimm * get the parent page
483a3ec5f4aSmatthiasgrimm *
484a3ec5f4aSmatthiasgrimm * Tries to find out which page is parent.
485a3ec5f4aSmatthiasgrimm * returns false if none is available
486a3ec5f4aSmatthiasgrimm *
487377f9e97SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
488a3ec5f4aSmatthiasgrimm */
489377f9e97SAndreas Gohrfunction tpl_getparent($id) {
490377f9e97SAndreas Gohr    $parent = getNS($id).':';
491377f9e97SAndreas Gohr    resolve_pageid('', $parent, $exists);
492a197105eSmatthiasgrimm    if($parent == $id) {
493a197105eSmatthiasgrimm        $pos    = strrpos(getNS($id), ':');
494a197105eSmatthiasgrimm        $parent = substr($parent, 0, $pos).':';
495a197105eSmatthiasgrimm        resolve_pageid('', $parent, $exists);
496377f9e97SAndreas Gohr        if($parent == $id) return false;
497a197105eSmatthiasgrimm    }
498377f9e97SAndreas Gohr    return $parent;
499a3ec5f4aSmatthiasgrimm}
500a3ec5f4aSmatthiasgrimm
501a3ec5f4aSmatthiasgrimm/**
5026b13307fSandi * Print one of the buttons
5036b13307fSandi *
504a453d131SAdrian Lang * @author Adrian Lang <mail@adrianlang.de>
505a453d131SAdrian Lang * @see    tpl_get_action
5066b13307fSandi */
5071af98a77SAnika Henkefunction tpl_button($type, $return = false) {
508a453d131SAdrian Lang    $data = tpl_get_action($type);
509a453d131SAdrian Lang    if($data === false) {
510a453d131SAdrian Lang        return false;
511a453d131SAdrian Lang    } elseif(!is_array($data)) {
512a453d131SAdrian Lang        $out = sprintf($data, 'button');
513409d7af7SAndreas Gohr    } else {
514ac7a515fSAndreas Gohr        /**
515ac7a515fSAndreas Gohr         * @var string $accesskey
516ac7a515fSAndreas Gohr         * @var string $id
517ac7a515fSAndreas Gohr         * @var string $method
518ac7a515fSAndreas Gohr         * @var array  $params
519ac7a515fSAndreas Gohr         */
520a453d131SAdrian Lang        extract($data);
521a453d131SAdrian Lang        if($id === '#dokuwiki__top') {
522a453d131SAdrian Lang            $out = html_topbtn();
523409d7af7SAndreas Gohr        } else {
524a453d131SAdrian Lang            $out = html_btn($type, $id, $accesskey, $params, $method);
525409d7af7SAndreas Gohr        }
526409d7af7SAndreas Gohr    }
5271af98a77SAnika Henke    if($return) return $out;
528a453d131SAdrian Lang    echo $out;
529a453d131SAdrian Lang    return true;
5306b13307fSandi}
5316b13307fSandi
5326b13307fSandi/**
533ed630903Sandi * Like the action buttons but links
534ed630903Sandi *
535a453d131SAdrian Lang * @author Adrian Lang <mail@adrianlang.de>
536a453d131SAdrian Lang * @see    tpl_get_action
537a453d131SAdrian Lang */
538a453d131SAdrian Langfunction tpl_actionlink($type, $pre = '', $suf = '', $inner = '', $return = false) {
539a453d131SAdrian Lang    global $lang;
540a453d131SAdrian Lang    $data = tpl_get_action($type);
541a453d131SAdrian Lang    if($data === false) {
542a453d131SAdrian Lang        return false;
543a453d131SAdrian Lang    } elseif(!is_array($data)) {
544a453d131SAdrian Lang        $out = sprintf($data, 'link');
545a453d131SAdrian Lang    } else {
546ac7a515fSAndreas Gohr        /**
547ac7a515fSAndreas Gohr         * @var string $accesskey
548ac7a515fSAndreas Gohr         * @var string $id
549ac7a515fSAndreas Gohr         * @var string $method
550b1af9014SChristopher Smith         * @var bool   $nofollow
551ac7a515fSAndreas Gohr         * @var array  $params
552becfa414SGerrit Uitslag         * @var string $replacement
553ac7a515fSAndreas Gohr         */
554a453d131SAdrian Lang        extract($data);
555a453d131SAdrian Lang        if(strpos($id, '#') === 0) {
556a453d131SAdrian Lang            $linktarget = $id;
557a453d131SAdrian Lang        } else {
558a453d131SAdrian Lang            $linktarget = wl($id, $params);
559a453d131SAdrian Lang        }
560a453d131SAdrian Lang        $caption = $lang['btn_'.$type];
561becfa414SGerrit Uitslag        if(strpos($caption, '%s')){
562becfa414SGerrit Uitslag            $caption = sprintf($caption, $replacement);
563becfa414SGerrit Uitslag        }
564c7e90e3fSAnika Henke        $akey    = $addTitle = '';
565c7e90e3fSAnika Henke        if($accesskey) {
566c7e90e3fSAnika Henke            $akey     = 'accesskey="'.$accesskey.'" ';
567c7e90e3fSAnika Henke            $addTitle = ' ['.strtoupper($accesskey).']';
568c7e90e3fSAnika Henke        }
569b1af9014SChristopher Smith        $rel = $nofollow ? 'rel="nofollow" ' : '';
570ac7a515fSAndreas Gohr        $out = tpl_link(
571ac7a515fSAndreas Gohr            $linktarget, $pre.(($inner) ? $inner : $caption).$suf,
572a453d131SAdrian Lang            'class="action '.$type.'" '.
573b1af9014SChristopher Smith                $akey.$rel.
574ac7a515fSAndreas Gohr                'title="'.hsc($caption).$addTitle.'"', 1
575ac7a515fSAndreas Gohr        );
576a453d131SAdrian Lang    }
577a453d131SAdrian Lang    if($return) return $out;
578a453d131SAdrian Lang    echo $out;
579a453d131SAdrian Lang    return true;
580a453d131SAdrian Lang}
581a453d131SAdrian Lang
582a453d131SAdrian Lang/**
583a453d131SAdrian Lang * Check the actions and get data for buttons and links
584ed630903Sandi *
585a453d131SAdrian Lang * Available actions are
586a453d131SAdrian Lang *
587a453d131SAdrian Lang *  edit        - edit/create/show/draft
588ed630903Sandi *  history     - old revisions
589ed630903Sandi *  recent      - recent changes
590a453d131SAdrian Lang *  login       - login/logout - if ACL enabled
591a453d131SAdrian Lang *  profile     - user profile (if logged in)
592ed630903Sandi *  index       - The index
593ed630903Sandi *  admin       - admin page - if enough rights
594a453d131SAdrian Lang *  top         - back to top
595a453d131SAdrian Lang *  back        - back to parent - if available
596bbd37938SAndreas Gohr *  backlink    - links to the list of backlinks
597a453d131SAdrian Lang *  subscribe/subscription- subscribe/unsubscribe
598ed630903Sandi *
599ed630903Sandi * @author Andreas Gohr <andi@splitbrain.org>
600a3ec5f4aSmatthiasgrimm * @author Matthias Grimm <matthiasgrimm@users.sourceforge.net>
601a453d131SAdrian Lang * @author Adrian Lang <mail@adrianlang.de>
602ac7a515fSAndreas Gohr * @param string $type
603ac7a515fSAndreas Gohr * @return array|bool|string
604ed630903Sandi */
605a453d131SAdrian Langfunction tpl_get_action($type) {
606ed630903Sandi    global $ID;
607ed630903Sandi    global $INFO;
608ed630903Sandi    global $REV;
609ed630903Sandi    global $ACT;
610b1af9014SChristopher Smith    global $conf;
611585bf44eSChristopher Smith    /** @var Input $INPUT */
612585bf44eSChristopher Smith    global $INPUT;
613ed630903Sandi
61475e487e9SAndreas Gohr    // check disabled actions and fix the badly named ones
615a453d131SAdrian Lang    if($type == 'history') $type = 'revisions';
6164c4b65c8SMichael Hamann    if ($type == 'subscription') $type = 'subscribe';
617a453d131SAdrian Lang    if(!actionOK($type)) return false;
618409d7af7SAndreas Gohr
619a453d131SAdrian Lang    $accesskey   = null;
6206709e843SAdrian Lang    $id          = $ID;
621a453d131SAdrian Lang    $method      = 'get';
622a453d131SAdrian Lang    $params      = array('do' => $type);
623b1af9014SChristopher Smith    $nofollow    = true;
624becfa414SGerrit Uitslag    $replacement = '';
625ed630903Sandi    switch($type) {
626ed630903Sandi        case 'edit':
6270b17fdc6SAndreas Gohr            // most complicated type - we need to decide on current action
628ed630903Sandi            if($ACT == 'show' || $ACT == 'search') {
629a453d131SAdrian Lang                $method = 'post';
630ed630903Sandi                if($INFO['writable']) {
631a453d131SAdrian Lang                    $accesskey = 'e';
632b8a111f5SMichael Klier                    if(!empty($INFO['draft'])) {
6336709e843SAdrian Lang                        $type         = 'draft';
634a453d131SAdrian Lang                        $params['do'] = 'draft';
635b8a111f5SMichael Klier                    } else {
636a453d131SAdrian Lang                        $params['rev'] = $REV;
637a453d131SAdrian Lang                        if(!$INFO['exists']) {
6386709e843SAdrian Lang                            $type = 'create';
639ed630903Sandi                        }
640b8a111f5SMichael Klier                    }
641ed630903Sandi                } else {
642a453d131SAdrian Lang                    if(!actionOK('source')) return false; //pseudo action
643a453d131SAdrian Lang                    $params['rev'] = $REV;
6446709e843SAdrian Lang                    $type          = 'source';
645a453d131SAdrian Lang                    $accesskey     = 'v';
646ed630903Sandi                }
647ed630903Sandi            } else {
648d30d4913SChristopher Smith                $params    = array('do' => '');
6496709e843SAdrian Lang                $type      = 'show';
650a453d131SAdrian Lang                $accesskey = 'v';
651ed630903Sandi            }
6521af98a77SAnika Henke            break;
653a453d131SAdrian Lang        case 'revisions':
6546709e843SAdrian Lang            $type      = 'revs';
655a453d131SAdrian Lang            $accesskey = 'o';
6561af98a77SAnika Henke            break;
657ed630903Sandi        case 'recent':
658a453d131SAdrian Lang            $accesskey = 'r';
6591af98a77SAnika Henke            break;
660ed630903Sandi        case 'index':
661a453d131SAdrian Lang            $accesskey = 'x';
662b1af9014SChristopher Smith            // allow searchbots to get to the sitemap from the homepage (when dokuwiki isn't providing a sitemap.xml)
663b1af9014SChristopher Smith            if ($conf['start'] == $ID && !$conf['sitemap']) {
664b1af9014SChristopher Smith                $nofollow = false;
665b1af9014SChristopher Smith            }
6661af98a77SAnika Henke            break;
667ed630903Sandi        case 'top':
668076f0d72SAnika Henke            $accesskey = 't';
669d30d4913SChristopher Smith            $params    = array('do' => '');
670a453d131SAdrian Lang            $id        = '#dokuwiki__top';
6711af98a77SAnika Henke            break;
672a3ec5f4aSmatthiasgrimm        case 'back':
673a453d131SAdrian Lang            $parent = tpl_getparent($ID);
674a453d131SAdrian Lang            if(!$parent) {
675a453d131SAdrian Lang                return false;
676a3ec5f4aSmatthiasgrimm            }
677a453d131SAdrian Lang            $id        = $parent;
678d30d4913SChristopher Smith            $params    = array('do' => '');
679a453d131SAdrian Lang            $accesskey = 'b';
6801af98a77SAnika Henke            break;
681becfa414SGerrit Uitslag        case 'img_backto':
682becfa414SGerrit Uitslag            $params = array();
683becfa414SGerrit Uitslag            $accesskey = 'b';
684becfa414SGerrit Uitslag            $replacement = $ID;
685becfa414SGerrit Uitslag            break;
686ed630903Sandi        case 'login':
687a453d131SAdrian Lang            $params['sectok'] = getSecurityToken();
688585bf44eSChristopher Smith            if($INPUT->server->has('REMOTE_USER')) {
6893a48618aSAnika Henke                if(!actionOK('logout')) {
6902380e8a8SAdrian Lang                    return false;
6912380e8a8SAdrian Lang                }
692a453d131SAdrian Lang                $params['do'] = 'logout';
693a453d131SAdrian Lang                $type         = 'logout';
694bf413a4eSAnika Henke            }
695bf413a4eSAnika Henke            break;
696bf413a4eSAnika Henke        case 'register':
697585bf44eSChristopher Smith            if($INPUT->server->str('REMOTE_USER')) {
698bf413a4eSAnika Henke                return false;
699bf413a4eSAnika Henke            }
700bf413a4eSAnika Henke            break;
701bf413a4eSAnika Henke        case 'resendpwd':
702585bf44eSChristopher Smith            if($INPUT->server->str('REMOTE_USER')) {
703bf413a4eSAnika Henke                return false;
704ed630903Sandi            }
7051af98a77SAnika Henke            break;
706ed630903Sandi        case 'admin':
707a453d131SAdrian Lang            if(!$INFO['ismanager']) {
708a453d131SAdrian Lang                return false;
709c059e1a6SAndreas Gohr            }
7101af98a77SAnika Henke            break;
7111246e016SAndreas Gohr        case 'revert':
712a453d131SAdrian Lang            if(!$INFO['ismanager'] || !$REV || !$INFO['writable']) {
713a453d131SAdrian Lang                return false;
7141246e016SAndreas Gohr            }
715a453d131SAdrian Lang            $params['rev']    = $REV;
716a453d131SAdrian Lang            $params['sectok'] = getSecurityToken();
7171246e016SAndreas Gohr            break;
7186709e843SAdrian Lang        case 'subscribe':
719585bf44eSChristopher Smith            if(!$INPUT->server->str('REMOTE_USER')) {
720a453d131SAdrian Lang                return false;
721b158d625SSteven Danz            }
7221af98a77SAnika Henke            break;
723f00151b4Schris        case 'backlink':
7241af98a77SAnika Henke            break;
7258b06d178Schris        case 'profile':
726585bf44eSChristopher Smith            if(!$INPUT->server->has('REMOTE_USER')) {
727a453d131SAdrian Lang                return false;
7288b06d178Schris            }
7291af98a77SAnika Henke            break;
730b9eb2e61SKate Arzamastseva        case 'media':
731d08527abSAnika Henke            $params['ns'] = getNS($ID);
732b9eb2e61SKate Arzamastseva            break;
733becfa414SGerrit Uitslag        case 'mediaManager':
734becfa414SGerrit Uitslag            // View image in media manager
735becfa414SGerrit Uitslag            global $IMG;
736becfa414SGerrit Uitslag            $imgNS = getNS($IMG);
737becfa414SGerrit Uitslag            $authNS = auth_quickaclcheck("$imgNS:*");
738becfa414SGerrit Uitslag            if ($authNS < AUTH_UPLOAD) {
739becfa414SGerrit Uitslag                return false;
740becfa414SGerrit Uitslag            }
741becfa414SGerrit Uitslag            $params = array(
742becfa414SGerrit Uitslag                'ns' => $imgNS,
743becfa414SGerrit Uitslag                'image' => $IMG,
744becfa414SGerrit Uitslag                'do' => 'media'
745becfa414SGerrit Uitslag            );
746becfa414SGerrit Uitslag            //$type = 'media';
747becfa414SGerrit Uitslag            break;
748ed630903Sandi        default:
749a453d131SAdrian Lang            return '[unknown %s type]';
7501af98a77SAnika Henke            break;
751ed630903Sandi    }
752becfa414SGerrit Uitslag    return compact('accesskey', 'type', 'id', 'method', 'params', 'nofollow', 'replacement');
753ed630903Sandi}
754ed630903Sandi
755ed630903Sandi/**
75601f17825SAnika Henke * Wrapper around tpl_button() and tpl_actionlink()
75701f17825SAnika Henke *
75801f17825SAnika Henke * @author Anika Henke <anika@selfthinker.org>
759ac7a515fSAndreas Gohr * @param
760ac7a515fSAndreas Gohr * @param bool   $link link or form button?
761ac7a515fSAndreas Gohr * @param bool   $wrapper HTML element wrapper
762ac7a515fSAndreas Gohr * @param bool   $return return or print
763ac7a515fSAndreas Gohr * @param string $pre prefix for links
764ac7a515fSAndreas Gohr * @param string $suf suffix for links
765ac7a515fSAndreas Gohr * @param string $inner inner HTML for links
766ac7a515fSAndreas Gohr * @return bool|string
76701f17825SAnika Henke */
768ac7a515fSAndreas Gohrfunction tpl_action($type, $link = false, $wrapper = false, $return = false, $pre = '', $suf = '', $inner = '') {
76901f17825SAnika Henke    $out = '';
770ac7a515fSAndreas Gohr    if($link) {
771ac7a515fSAndreas Gohr        $out .= tpl_actionlink($type, $pre, $suf, $inner, 1);
772ac7a515fSAndreas Gohr    } else {
773ac7a515fSAndreas Gohr        $out .= tpl_button($type, 1);
774ac7a515fSAndreas Gohr    }
77501f17825SAnika Henke    if($out && $wrapper) $out = "<$wrapper>$out</$wrapper>";
77601f17825SAnika Henke
77701f17825SAnika Henke    if($return) return $out;
77801f17825SAnika Henke    print $out;
77901f17825SAnika Henke    return $out ? true : false;
78001f17825SAnika Henke}
78101f17825SAnika Henke
78201f17825SAnika Henke/**
7836b13307fSandi * Print the search form
7846b13307fSandi *
78572645b75SAndreas Gohr * If the first parameter is given a div with the ID 'qsearch_out' will
78672645b75SAndreas Gohr * be added which instructs the ajax pagequicksearch to kick in and place
78772645b75SAndreas Gohr * its output into this div. The second parameter controls the propritary
78872645b75SAndreas Gohr * attribute autocomplete. If set to false this attribute will be set with an
78972645b75SAndreas Gohr * value of "off" to instruct the browser to disable it's own built in
79072645b75SAndreas Gohr * autocompletion feature (MSIE and Firefox)
79172645b75SAndreas Gohr *
7926b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
793ac7a515fSAndreas Gohr * @param bool $ajax
794ac7a515fSAndreas Gohr * @param bool $autocomplete
795ac7a515fSAndreas Gohr * @return bool
7966b13307fSandi */
79772645b75SAndreas Gohrfunction tpl_searchform($ajax = true, $autocomplete = true) {
7986b13307fSandi    global $lang;
799c1e3b7d9Smatthiasgrimm    global $ACT;
800ad4aaef7SAndreas Gohr    global $QUERY;
801c1e3b7d9Smatthiasgrimm
802670ff54eSchris    // don't print the search form if search action has been disabled
80364276bbcSarbrk1    if(!actionOK('search')) return false;
804670ff54eSchris
8059805efa0SAnika Henke    print '<form action="'.wl().'" accept-charset="utf-8" class="search" id="dw__search" method="get" role="search"><div class="no">';
8066b13307fSandi    print '<input type="hidden" name="do" value="search" />';
807c1e3b7d9Smatthiasgrimm    print '<input type="text" ';
808ad4aaef7SAndreas Gohr    if($ACT == 'search') print 'value="'.htmlspecialchars($QUERY).'" ';
80972645b75SAndreas Gohr    if(!$autocomplete) print 'autocomplete="off" ';
81007493d05SAnika Henke    print 'id="qsearch__in" accesskey="f" name="id" class="edit" title="[F]" />';
81111ea018fSAndreas Gohr    print '<input type="submit" value="'.$lang['btn_search'].'" class="button" title="'.$lang['btn_search'].'" />';
81224a33b42SAndreas Gohr    if($ajax) print '<div id="qsearch__out" class="ajax_qsearch JSpopup"></div>';
8134beabca9SAnika Henke    print '</div></form>';
81454e95700STom N Harris    return true;
8156b13307fSandi}
8166b13307fSandi
8176b13307fSandi/**
8186b13307fSandi * Print the breadcrumbs trace
8196b13307fSandi *
8206b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
821ac7a515fSAndreas Gohr * @param string $sep Separator between entries
822ac7a515fSAndreas Gohr * @return bool
8236b13307fSandi */
824e260f93bSAnika Henkefunction tpl_breadcrumbs($sep = '•') {
8256b13307fSandi    global $lang;
8266b13307fSandi    global $conf;
8276b13307fSandi
8286b13307fSandi    //check if enabled
829359fab8bSMichael Hamann    if(!$conf['breadcrumbs']) return false;
8306b13307fSandi
8316b13307fSandi    $crumbs = breadcrumbs(); //setup crumb trace
832265e3787Sandi
8332979a10bSKatriel Traum    $crumbs_sep = ' <span class="bcsep">'.$sep.'</span> ';
834265e3787Sandi
83540eb54bbSjan    //render crumbs, highlight the last one
836fde860beSGerrit Uitslag    print '<span class="bchead">'.$lang['breadcrumb'].'</span>';
83740eb54bbSjan    $last = count($crumbs);
83840eb54bbSjan    $i    = 0;
839a77f5846Sjan    foreach($crumbs as $id => $name) {
84040eb54bbSjan        $i++;
8412979a10bSKatriel Traum        echo $crumbs_sep;
84292795d04Sandi        if($i == $last) print '<span class="curid">';
843d317fb5dSAnika Henke        print '<bdi>';
844e26fd1eeSAndreas Gohr        tpl_link(wl($id), hsc($name), 'class="breadcrumbs" title="'.$id.'"');
845d317fb5dSAnika Henke        print '</bdi>';
84692795d04Sandi        if($i == $last) print '</span>';
8476b13307fSandi    }
84854e95700STom N Harris    return true;
8496b13307fSandi}
8506b13307fSandi
8516b13307fSandi/**
8521734437eSandi * Hierarchical breadcrumbs
8531734437eSandi *
85431e187f8SSean Coates * This code was suggested as replacement for the usual breadcrumbs.
8551734437eSandi * It only makes sense with a deep site structure.
8561734437eSandi *
8571734437eSandi * @author Andreas Gohr <andi@splitbrain.org>
8586bd812dfSNigel McNie * @author Nigel McNie <oracle.shinoda@gmail.com>
85931e187f8SSean Coates * @author Sean Coates <sean@caedmon.net>
860f46c9e83SAnika Henke * @author <fredrik@averpil.com>
8616bd812dfSNigel McNie * @todo   May behave strangely in RTL languages
862ac7a515fSAndreas Gohr * @param string $sep Separator between entries
863ac7a515fSAndreas Gohr * @return bool
8641734437eSandi */
865e260f93bSAnika Henkefunction tpl_youarehere($sep = ' » ') {
8661734437eSandi    global $conf;
8671734437eSandi    global $ID;
8681734437eSandi    global $lang;
8691734437eSandi
87031e187f8SSean Coates    // check if enabled
87154e95700STom N Harris    if(!$conf['youarehere']) return false;
8721734437eSandi
8731734437eSandi    $parts = explode(':', $ID);
874796bafb3SAndreas Gohr    $count = count($parts);
8751734437eSandi
876fde860beSGerrit Uitslag    echo '<span class="bchead">'.$lang['youarehere'].' </span>';
8771734437eSandi
8781734437eSandi    // always print the startpage
879fca4df27SAnika Henke    echo '<span class="home">';
880e013f48dSAnika Henke    tpl_pagelink(':'.$conf['start']);
881fca4df27SAnika Henke    echo '</span>';
882796bafb3SAndreas Gohr
883796bafb3SAndreas Gohr    // print intermediate namespace links
884796bafb3SAndreas Gohr    $part = '';
885796bafb3SAndreas Gohr    for($i = 0; $i < $count - 1; $i++) {
886796bafb3SAndreas Gohr        $part .= $parts[$i].':';
887796bafb3SAndreas Gohr        $page = $part;
888796bafb3SAndreas Gohr        if($page == $conf['start']) continue; // Skip startpage
889796bafb3SAndreas Gohr
890796bafb3SAndreas Gohr        // output
891796bafb3SAndreas Gohr        echo $sep;
892e013f48dSAnika Henke        tpl_pagelink($page);
89331e187f8SSean Coates    }
8941734437eSandi
895796bafb3SAndreas Gohr    // print current page, skipping start page, skipping for namespace index
896e013f48dSAnika Henke    resolve_pageid('', $page, $exists);
897ac7a515fSAndreas Gohr    if(isset($page) && $page == $part.$parts[$i]) return true;
898796bafb3SAndreas Gohr    $page = $part.$parts[$i];
899ac7a515fSAndreas Gohr    if($page == $conf['start']) return true;
900796bafb3SAndreas Gohr    echo $sep;
901e013f48dSAnika Henke    tpl_pagelink($page);
90254e95700STom N Harris    return true;
9031734437eSandi}
9041734437eSandi
9051734437eSandi/**
9066b13307fSandi * Print info if the user is logged in
907a2488c3cSMatthias Grimm * and show full name in that case
9086b13307fSandi *
9096b13307fSandi * Could be enhanced with a profile link in future?
9106b13307fSandi *
9116b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
912ac7a515fSAndreas Gohr * @return bool
9136b13307fSandi */
9146b13307fSandifunction tpl_userinfo() {
9156b13307fSandi    global $lang;
916585bf44eSChristopher Smith    /** @var Input $INPUT */
917585bf44eSChristopher Smith    global $INPUT;
918585bf44eSChristopher Smith
919585bf44eSChristopher Smith    if($INPUT->server->str('REMOTE_USER')) {
920fde860beSGerrit Uitslag        print $lang['loggedinas'].' '.userlink();
92154e95700STom N Harris        return true;
92254e95700STom N Harris    }
92354e95700STom N Harris    return false;
9246b13307fSandi}
9256b13307fSandi
9266b13307fSandi/**
9276b13307fSandi * Print some info about the current page
9286b13307fSandi *
9296b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
930ac7a515fSAndreas Gohr * @param bool $ret return content instead of printing it
931ac7a515fSAndreas Gohr * @return bool|string
9326b13307fSandi */
9334b0d3916SAndreas Gohrfunction tpl_pageinfo($ret = false) {
9346b13307fSandi    global $conf;
9356b13307fSandi    global $lang;
9366b13307fSandi    global $INFO;
937c6e92a3cSDavid Lorentsen    global $ID;
938c6e92a3cSDavid Lorentsen
939c6e92a3cSDavid Lorentsen    // return if we are not allowed to view the page
940ac7a515fSAndreas Gohr    if(!auth_quickaclcheck($ID)) {
941ac7a515fSAndreas Gohr        return false;
942ac7a515fSAndreas Gohr    }
9436b13307fSandi
9446b13307fSandi    // prepare date and path
9456b13307fSandi    $fn = $INFO['filepath'];
9466b13307fSandi    if(!$conf['fullpath']) {
947613bca54SAndreas Gohr        if($INFO['rev']) {
94850fbebceSGina Haeussge            $fn = str_replace(fullpath($conf['olddir']).'/', '', $fn);
9496b13307fSandi        } else {
95050fbebceSGina Haeussge            $fn = str_replace(fullpath($conf['datadir']).'/', '', $fn);
9516b13307fSandi        }
9526b13307fSandi    }
953bee6dc82Sandi    $fn   = utf8_decodeFN($fn);
954f2263577SAndreas Gohr    $date = dformat($INFO['lastmod']);
9556b13307fSandi
956faecdfdfSAndreas Gohr    // print it
957faecdfdfSAndreas Gohr    if($INFO['exists']) {
9584b0d3916SAndreas Gohr        $out = '';
959d317fb5dSAnika Henke        $out .= '<bdi>'.$fn.'</bdi>';
960e260f93bSAnika Henke        $out .= ' · ';
9614b0d3916SAndreas Gohr        $out .= $lang['lastmod'];
962fde860beSGerrit Uitslag        $out .= ' ';
9634b0d3916SAndreas Gohr        $out .= $date;
9646b13307fSandi        if($INFO['editor']) {
9654b0d3916SAndreas Gohr            $out .= ' '.$lang['by'].' ';
966d317fb5dSAnika Henke            $out .= '<bdi>'.editorinfo($INFO['editor']).'</bdi>';
9675aa52fafSBen Coburn        } else {
9684b0d3916SAndreas Gohr            $out .= ' ('.$lang['external_edit'].')';
9696b13307fSandi        }
9706b13307fSandi        if($INFO['locked']) {
971e260f93bSAnika Henke            $out .= ' · ';
9724b0d3916SAndreas Gohr            $out .= $lang['lockedby'];
973fde860beSGerrit Uitslag            $out .= ' ';
974d317fb5dSAnika Henke            $out .= '<bdi>'.editorinfo($INFO['locked']).'</bdi>';
9756b13307fSandi        }
9764b0d3916SAndreas Gohr        if($ret) {
9774b0d3916SAndreas Gohr            return $out;
9784b0d3916SAndreas Gohr        } else {
9794b0d3916SAndreas Gohr            echo $out;
98054e95700STom N Harris            return true;
9816b13307fSandi        }
9824b0d3916SAndreas Gohr    }
98354e95700STom N Harris    return false;
9846b13307fSandi}
9856b13307fSandi
986820fa24bSandi/**
987a6598f23SBen Coburn * Prints or returns the name of the given page (current one if none given).
98887c434ceSAndreas Gohr *
98987c434ceSAndreas Gohr * If useheading is enabled this will use the first headline else
990a6598f23SBen Coburn * the given ID is used.
99187c434ceSAndreas Gohr *
99287c434ceSAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
993ac7a515fSAndreas Gohr * @param string $id page id
994ac7a515fSAndreas Gohr * @param bool   $ret return content instead of printing
995ac7a515fSAndreas Gohr * @return bool|string
99687c434ceSAndreas Gohr */
997a6598f23SBen Coburnfunction tpl_pagetitle($id = null, $ret = false) {
99887c434ceSAndreas Gohr    if(is_null($id)) {
99987c434ceSAndreas Gohr        global $ID;
100087c434ceSAndreas Gohr        $id = $ID;
100187c434ceSAndreas Gohr    }
100287c434ceSAndreas Gohr
100387c434ceSAndreas Gohr    $name = $id;
1004fe9ec250SChris Smith    if(useHeading('navigation')) {
100587c434ceSAndreas Gohr        $title = p_get_first_heading($id);
100687c434ceSAndreas Gohr        if($title) $name = $title;
100787c434ceSAndreas Gohr    }
1008a6598f23SBen Coburn
1009a6598f23SBen Coburn    if($ret) {
1010a6598f23SBen Coburn        return hsc($name);
1011a6598f23SBen Coburn    } else {
101287c434ceSAndreas Gohr        print hsc($name);
101354e95700STom N Harris        return true;
101487c434ceSAndreas Gohr    }
1015a6598f23SBen Coburn}
1016340756e4Sandi
101755efc227SAndreas Gohr/**
101855efc227SAndreas Gohr * Returns the requested EXIF/IPTC tag from the current image
101955efc227SAndreas Gohr *
102055efc227SAndreas Gohr * If $tags is an array all given tags are tried until a
102155efc227SAndreas Gohr * value is found. If no value is found $alt is returned.
102255efc227SAndreas Gohr *
102355efc227SAndreas Gohr * Which texts are known is defined in the functions _exifTagNames
102455efc227SAndreas Gohr * and _iptcTagNames() in inc/jpeg.php (You need to prepend IPTC
102555efc227SAndreas Gohr * to the names of the latter one)
102655efc227SAndreas Gohr *
10273df72098SAndreas Gohr * Only allowed in: detail.php
102855efc227SAndreas Gohr *
102955efc227SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
1030ac7a515fSAndreas Gohr * @param array  $tags tags to try
1031ac7a515fSAndreas Gohr * @param string $alt alternative output if no data was found
1032ac7a515fSAndreas Gohr * @param null   $src the image src, uses global $SRC if not given
1033ac7a515fSAndreas Gohr * @return string
103455efc227SAndreas Gohr */
10353df72098SAndreas Gohrfunction tpl_img_getTag($tags, $alt = '', $src = null) {
103655efc227SAndreas Gohr    // Init Exif Reader
103755efc227SAndreas Gohr    global $SRC;
10383df72098SAndreas Gohr
10393df72098SAndreas Gohr    if(is_null($src)) $src = $SRC;
10403df72098SAndreas Gohr
104155efc227SAndreas Gohr    static $meta = null;
10423df72098SAndreas Gohr    if(is_null($meta)) $meta = new JpegMeta($src);
104355efc227SAndreas Gohr    if($meta === false) return $alt;
104488945224SChristopher Smith    $info = cleanText($meta->getField($tags));
104555efc227SAndreas Gohr    if($info == false) return $alt;
104655efc227SAndreas Gohr    return $info;
104755efc227SAndreas Gohr}
104855efc227SAndreas Gohr
104955efc227SAndreas Gohr/**
1050becfa414SGerrit Uitslag * Returns a description list of the metatags of the current image
1051becfa414SGerrit Uitslag *
1052becfa414SGerrit Uitslag * @return string html of description list
1053becfa414SGerrit Uitslag */
1054becfa414SGerrit Uitslagfunction tpl_img_meta() {
1055becfa414SGerrit Uitslag    global $lang;
1056becfa414SGerrit Uitslag
1057becfa414SGerrit Uitslag    $tags = tpl_get_img_meta();
1058becfa414SGerrit Uitslag
1059becfa414SGerrit Uitslag    echo '<dl>';
1060becfa414SGerrit Uitslag    foreach($tags as $tag) {
1061becfa414SGerrit Uitslag        $label = $lang[$tag['langkey']];
1062fde860beSGerrit Uitslag        if(!$label) $label = $tag['langkey'] . ':';
1063becfa414SGerrit Uitslag
1064fde860beSGerrit Uitslag        echo '<dt>'.$label.'</dt><dd>';
1065becfa414SGerrit Uitslag        if ($tag['type'] == 'date') {
1066becfa414SGerrit Uitslag            echo dformat($tag['value']);
1067becfa414SGerrit Uitslag        } else {
1068becfa414SGerrit Uitslag            echo hsc($tag['value']);
1069becfa414SGerrit Uitslag        }
1070becfa414SGerrit Uitslag        echo '</dd>';
1071becfa414SGerrit Uitslag    }
1072becfa414SGerrit Uitslag    echo '</dl>';
1073becfa414SGerrit Uitslag}
1074becfa414SGerrit Uitslag
1075becfa414SGerrit Uitslag/**
1076becfa414SGerrit Uitslag * Returns metadata as configured in mediameta config file, ready for creating html
1077becfa414SGerrit Uitslag *
1078becfa414SGerrit Uitslag * @return array with arrays containing the entries:
1079becfa414SGerrit Uitslag *   - string langkey  key to lookup in the $lang var, if not found printed as is
1080becfa414SGerrit Uitslag *   - string type     type of value
1081becfa414SGerrit Uitslag *   - string value    tag value (unescaped)
1082becfa414SGerrit Uitslag */
1083becfa414SGerrit Uitslagfunction tpl_get_img_meta() {
1084becfa414SGerrit Uitslag
1085becfa414SGerrit Uitslag    $config_files = getConfigFiles('mediameta');
1086becfa414SGerrit Uitslag    foreach ($config_files as $config_file) {
1087becfa414SGerrit Uitslag        if(@file_exists($config_file)) {
1088becfa414SGerrit Uitslag            include($config_file);
1089becfa414SGerrit Uitslag        }
1090becfa414SGerrit Uitslag    }
1091becfa414SGerrit Uitslag    /** @var array $fields the included array with metadata */
1092becfa414SGerrit Uitslag
1093becfa414SGerrit Uitslag    $tags = array();
1094becfa414SGerrit Uitslag    foreach($fields as $tag){
1095becfa414SGerrit Uitslag        $t = array();
1096becfa414SGerrit Uitslag        if (!empty($tag[0])) {
1097becfa414SGerrit Uitslag            $t = array($tag[0]);
1098becfa414SGerrit Uitslag        }
1099becfa414SGerrit Uitslag        if(is_array($tag[3])) {
1100becfa414SGerrit Uitslag            $t = array_merge($t,$tag[3]);
1101becfa414SGerrit Uitslag        }
1102becfa414SGerrit Uitslag        $value = tpl_img_getTag($t);
1103becfa414SGerrit Uitslag        if ($value) {
1104becfa414SGerrit Uitslag            $tags[] = array('langkey' => $tag[1], 'type' => $tag[2], 'value' => $value);
1105becfa414SGerrit Uitslag        }
1106becfa414SGerrit Uitslag    }
1107becfa414SGerrit Uitslag    return $tags;
1108becfa414SGerrit Uitslag}
1109becfa414SGerrit Uitslag
1110becfa414SGerrit Uitslag/**
111155efc227SAndreas Gohr * Prints the image with a link to the full sized version
111255efc227SAndreas Gohr *
111355efc227SAndreas Gohr * Only allowed in: detail.php
1114a02d2933SAndreas Gohr *
1115ac7a515fSAndreas Gohr * @triggers TPL_IMG_DISPLAY
1116a02d2933SAndreas Gohr * @param $maxwidth  int - maximal width of the image
1117a02d2933SAndreas Gohr * @param $maxheight int - maximal height of the image
1118a02d2933SAndreas Gohr * @param $link bool     - link to the orginal size?
1119a02d2933SAndreas Gohr * @param $params array  - additional image attributes
1120ac7a515fSAndreas Gohr * @return mixed Result of TPL_IMG_DISPLAY
112155efc227SAndreas Gohr */
1122a02d2933SAndreas Gohrfunction tpl_img($maxwidth = 0, $maxheight = 0, $link = true, $params = null) {
112355efc227SAndreas Gohr    global $IMG;
1124585bf44eSChristopher Smith    /** @var Input $INPUT */
1125ac7a515fSAndreas Gohr    global $INPUT;
112655efc227SAndreas Gohr    $w = tpl_img_getTag('File.Width');
112755efc227SAndreas Gohr    $h = tpl_img_getTag('File.Height');
112855efc227SAndreas Gohr
112955efc227SAndreas Gohr    //resize to given max values
113023a34783SAndreas Gohr    $ratio = 1;
113123a34783SAndreas Gohr    if($w >= $h) {
1132f8925855Sjoe.lapp        if($maxwidth && $w >= $maxwidth) {
113355efc227SAndreas Gohr            $ratio = $maxwidth / $w;
1134f8925855Sjoe.lapp        } elseif($maxheight && $h > $maxheight) {
113555efc227SAndreas Gohr            $ratio = $maxheight / $h;
113655efc227SAndreas Gohr        }
113755efc227SAndreas Gohr    } else {
1138f8925855Sjoe.lapp        if($maxheight && $h >= $maxheight) {
113955efc227SAndreas Gohr            $ratio = $maxheight / $h;
1140f8925855Sjoe.lapp        } elseif($maxwidth && $w > $maxwidth) {
114155efc227SAndreas Gohr            $ratio = $maxwidth / $w;
114255efc227SAndreas Gohr        }
114355efc227SAndreas Gohr    }
114455efc227SAndreas Gohr    if($ratio) {
114555efc227SAndreas Gohr        $w = floor($ratio * $w);
114655efc227SAndreas Gohr        $h = floor($ratio * $h);
114755efc227SAndreas Gohr    }
114855efc227SAndreas Gohr
11496de3759aSAndreas Gohr    //prepare URLs
1150ac7a515fSAndreas Gohr    $url = ml($IMG, array('cache'=> $INPUT->str('cache')), true, '&');
1151ac7a515fSAndreas Gohr    $src = ml($IMG, array('cache'=> $INPUT->str('cache'), 'w'=> $w, 'h'=> $h), true, '&');
115255efc227SAndreas Gohr
11532684e50aSAndreas Gohr    //prepare attributes
115455efc227SAndreas Gohr    $alt = tpl_img_getTag('Simple.Title');
1155a02d2933SAndreas Gohr    if(is_null($params)) {
11562684e50aSAndreas Gohr        $p = array();
1157a02d2933SAndreas Gohr    } else {
1158a02d2933SAndreas Gohr        $p = $params;
1159a02d2933SAndreas Gohr    }
11602684e50aSAndreas Gohr    if($w) $p['width'] = $w;
11612684e50aSAndreas Gohr    if($h) $p['height'] = $h;
11622684e50aSAndreas Gohr    $p['class'] = 'img_detail';
11632684e50aSAndreas Gohr    if($alt) {
11642684e50aSAndreas Gohr        $p['alt']   = $alt;
11652684e50aSAndreas Gohr        $p['title'] = $alt;
11662684e50aSAndreas Gohr    } else {
11672684e50aSAndreas Gohr        $p['alt'] = '';
11682684e50aSAndreas Gohr    }
1169a02d2933SAndreas Gohr    $p['src'] = $src;
117055efc227SAndreas Gohr
1171a02d2933SAndreas Gohr    $data = array('url'=> ($link ? $url : null), 'params'=> $p);
1172a02d2933SAndreas Gohr    return trigger_event('TPL_IMG_DISPLAY', $data, '_tpl_img_action', true);
1173a02d2933SAndreas Gohr}
1174a02d2933SAndreas Gohr
1175a02d2933SAndreas Gohr/**
1176a02d2933SAndreas Gohr * Default action for TPL_IMG_DISPLAY
1177ac7a515fSAndreas Gohr *
1178ac7a515fSAndreas Gohr * @param array $data
1179ac7a515fSAndreas Gohr * @return bool
1180a02d2933SAndreas Gohr */
1181ac7a515fSAndreas Gohrfunction _tpl_img_action($data) {
118259f3611bSAnika Henke    global $lang;
1183a02d2933SAndreas Gohr    $p = buildAttributes($data['params']);
1184a02d2933SAndreas Gohr
118559f3611bSAnika Henke    if($data['url']) print '<a href="'.hsc($data['url']).'" title="'.$lang['mediaview'].'">';
1186a02d2933SAndreas Gohr    print '<img '.$p.'/>';
1187a02d2933SAndreas Gohr    if($data['url']) print '</a>';
118854e95700STom N Harris    return true;
118955efc227SAndreas Gohr}
119055efc227SAndreas Gohr
11917367b368SAndreas Gohr/**
1192881f2ee2SAndreas Haerter * This function inserts a small gif which in reality is the indexer function.
11937367b368SAndreas Gohr *
11947367b368SAndreas Gohr * Should be called somewhere at the very end of the main.php
11957367b368SAndreas Gohr * template
1196ac7a515fSAndreas Gohr *
1197ac7a515fSAndreas Gohr * @return bool
11987367b368SAndreas Gohr */
11997367b368SAndreas Gohrfunction tpl_indexerWebBug() {
12007367b368SAndreas Gohr    global $ID;
12011dad36f5SAndreas Gohr
12027367b368SAndreas Gohr    $p           = array();
1203b6c6979fSAndreas Gohr    $p['src']    = DOKU_BASE.'lib/exe/indexer.php?id='.rawurlencode($ID).
1204e68c51baSAndreas Gohr        '&'.time();
1205881f2ee2SAndreas Haerter    $p['width']  = 2; //no more 1x1 px image because we live in times of ad blockers...
12067367b368SAndreas Gohr    $p['height'] = 1;
12077367b368SAndreas Gohr    $p['alt']    = '';
12087367b368SAndreas Gohr    $att         = buildAttributes($p);
12097367b368SAndreas Gohr    print "<img $att />";
121054e95700STom N Harris    return true;
12117367b368SAndreas Gohr}
12127367b368SAndreas Gohr
121378d4e784SEsther Brunner/**
121478d4e784SEsther Brunner * tpl_getConf($id)
121578d4e784SEsther Brunner *
121678d4e784SEsther Brunner * use this function to access template configuration variables
1217ac7a515fSAndreas Gohr *
121817448fb8SChristopher Smith * @param string $id      name of the value to access
121917448fb8SChristopher Smith * @param mixed  $notset  what to return if the setting is not available
122017448fb8SChristopher Smith * @return mixed
122178d4e784SEsther Brunner */
122217448fb8SChristopher Smithfunction tpl_getConf($id, $notset=false) {
122378d4e784SEsther Brunner    global $conf;
122417566ac6SAdrian Lang    static $tpl_configloaded = false;
122578d4e784SEsther Brunner
122678d4e784SEsther Brunner    $tpl = $conf['template'];
122778d4e784SEsther Brunner
122878d4e784SEsther Brunner    if(!$tpl_configloaded) {
122978d4e784SEsther Brunner        $tconf = tpl_loadConfig();
123078d4e784SEsther Brunner        if($tconf !== false) {
123178d4e784SEsther Brunner            foreach($tconf as $key => $value) {
123278d4e784SEsther Brunner                if(isset($conf['tpl'][$tpl][$key])) continue;
123378d4e784SEsther Brunner                $conf['tpl'][$tpl][$key] = $value;
123478d4e784SEsther Brunner            }
123578d4e784SEsther Brunner            $tpl_configloaded = true;
123678d4e784SEsther Brunner        }
123778d4e784SEsther Brunner    }
123878d4e784SEsther Brunner
123917448fb8SChristopher Smith    if(isset($conf['tpl'][$tpl][$id])){
124078d4e784SEsther Brunner        return $conf['tpl'][$tpl][$id];
124178d4e784SEsther Brunner    }
124278d4e784SEsther Brunner
124317448fb8SChristopher Smith    return $notset;
124417448fb8SChristopher Smith}
124517448fb8SChristopher Smith
124678d4e784SEsther Brunner/**
124778d4e784SEsther Brunner * tpl_loadConfig()
1248ac7a515fSAndreas Gohr *
124978d4e784SEsther Brunner * reads all template configuration variables
125078d4e784SEsther Brunner * this function is automatically called by tpl_getConf()
1251ac7a515fSAndreas Gohr *
1252ac7a515fSAndreas Gohr * @return array
125378d4e784SEsther Brunner */
125478d4e784SEsther Brunnerfunction tpl_loadConfig() {
125578d4e784SEsther Brunner
1256c4766956SAndreas Gohr    $file = tpl_incdir().'/conf/default.php';
125778d4e784SEsther Brunner    $conf = array();
125878d4e784SEsther Brunner
125978d4e784SEsther Brunner    if(!@file_exists($file)) return false;
126078d4e784SEsther Brunner
126178d4e784SEsther Brunner    // load default config file
126278d4e784SEsther Brunner    include($file);
126378d4e784SEsther Brunner
126478d4e784SEsther Brunner    return $conf;
126578d4e784SEsther Brunner}
126678d4e784SEsther Brunner
126717566ac6SAdrian Lang// language methods
126817566ac6SAdrian Lang/**
126917566ac6SAdrian Lang * tpl_getLang($id)
127017566ac6SAdrian Lang *
127117566ac6SAdrian Lang * use this function to access template language variables
127217566ac6SAdrian Lang */
127317566ac6SAdrian Langfunction tpl_getLang($id) {
127417566ac6SAdrian Lang    static $lang = array();
127517566ac6SAdrian Lang
127617566ac6SAdrian Lang    if(count($lang) === 0) {
1277c4766956SAndreas Gohr        $path = tpl_incdir().'lang/';
127817566ac6SAdrian Lang
127917566ac6SAdrian Lang        $lang = array();
128017566ac6SAdrian Lang
128117566ac6SAdrian Lang        global $conf; // definitely don't invoke "global $lang"
128217566ac6SAdrian Lang        // don't include once
128317566ac6SAdrian Lang        @include($path.'en/lang.php');
128417566ac6SAdrian Lang        if($conf['lang'] != 'en') @include($path.$conf['lang'].'/lang.php');
128517566ac6SAdrian Lang    }
128617566ac6SAdrian Lang
128717566ac6SAdrian Lang    return $lang[$id];
128817566ac6SAdrian Lang}
128917566ac6SAdrian Lang
12903df72098SAndreas Gohr/**
1291c5c17fdaSKlap-in * Retrieve a language dependent file and pass to xhtml renderer for display
1292e8ec13b9SKlap-in * template equivalent of p_locale_xhtml()
1293e8ec13b9SKlap-in *
1294e8ec13b9SKlap-in * @param   string $id id of language dependent wiki page
1295e8ec13b9SKlap-in * @return  string     parsed contents of the wiki page in xhtml format
1296e8ec13b9SKlap-in */
1297e8ec13b9SKlap-infunction tpl_locale_xhtml($id) {
1298c5c17fdaSKlap-in    return p_cached_output(tpl_localeFN($id));
1299e8ec13b9SKlap-in}
1300e8ec13b9SKlap-in
1301e8ec13b9SKlap-in/**
1302c5c17fdaSKlap-in * Prepends appropriate path for a language dependent filename
1303e8ec13b9SKlap-in */
1304c5c17fdaSKlap-infunction tpl_localeFN($id) {
1305e8ec13b9SKlap-in    $path = tpl_incdir().'lang/';
1306e8ec13b9SKlap-in    global $conf;
1307e8ec13b9SKlap-in    $file = DOKU_CONF.'/template_lang/'.$conf['template'].'/'.$conf['lang'].'/'.$id.'.txt';
1308e8ec13b9SKlap-in    if (!@file_exists($file)){
1309e8ec13b9SKlap-in        $file = $path.$conf['lang'].'/'.$id.'.txt';
1310e8ec13b9SKlap-in        if(!@file_exists($file)){
1311e8ec13b9SKlap-in            //fall back to english
1312e8ec13b9SKlap-in            $file = $path.'en/'.$id.'.txt';
1313e8ec13b9SKlap-in        }
1314e8ec13b9SKlap-in    }
1315e8ec13b9SKlap-in    return $file;
1316e8ec13b9SKlap-in}
1317e8ec13b9SKlap-in
1318e8ec13b9SKlap-in/**
13193df72098SAndreas Gohr * prints the "main content" in the mediamanger popup
13203df72098SAndreas Gohr *
13213df72098SAndreas Gohr * Depending on the user's actions this may be a list of
13223df72098SAndreas Gohr * files in a namespace, the meta editing dialog or
13233df72098SAndreas Gohr * a message of referencing pages
13243df72098SAndreas Gohr *
13253df72098SAndreas Gohr * Only allowed in mediamanager.php
13263df72098SAndreas Gohr *
1327c182313eSAndreas Gohr * @triggers MEDIAMANAGER_CONTENT_OUTPUT
1328c182313eSAndreas Gohr * @param bool $fromajax - set true when calling this function via ajax
13293df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
13303df72098SAndreas Gohr */
133100e3e394SChristopher Smithfunction tpl_mediaContent($fromajax = false, $sort='natural') {
13323df72098SAndreas Gohr    global $IMG;
13333df72098SAndreas Gohr    global $AUTH;
13343df72098SAndreas Gohr    global $INUSE;
13353df72098SAndreas Gohr    global $NS;
13363df72098SAndreas Gohr    global $JUMPTO;
1337585bf44eSChristopher Smith    /** @var Input $INPUT */
1338ac7a515fSAndreas Gohr    global $INPUT;
13393df72098SAndreas Gohr
1340ac7a515fSAndreas Gohr    $do = $INPUT->extract('do')->str('do');
1341c182313eSAndreas Gohr    if(in_array($do, array('save', 'cancel'))) $do = '';
1342c182313eSAndreas Gohr
1343c182313eSAndreas Gohr    if(!$do) {
1344ac7a515fSAndreas Gohr        if($INPUT->bool('edit')) {
1345c182313eSAndreas Gohr            $do = 'metaform';
1346c182313eSAndreas Gohr        } elseif(is_array($INUSE)) {
1347c182313eSAndreas Gohr            $do = 'filesinuse';
1348c182313eSAndreas Gohr        } else {
1349c182313eSAndreas Gohr            $do = 'filelist';
1350c182313eSAndreas Gohr        }
1351c182313eSAndreas Gohr    }
1352c182313eSAndreas Gohr
1353c182313eSAndreas Gohr    // output the content pane, wrapped in an event.
1354c182313eSAndreas Gohr    if(!$fromajax) ptln('<div id="media__content">');
1355c182313eSAndreas Gohr    $data = array('do' => $do);
1356c182313eSAndreas Gohr    $evt  = new Doku_Event('MEDIAMANAGER_CONTENT_OUTPUT', $data);
1357c182313eSAndreas Gohr    if($evt->advise_before()) {
1358c182313eSAndreas Gohr        $do = $data['do'];
135930fd72fbSKate Arzamastseva        if($do == 'filesinuse') {
1360c182313eSAndreas Gohr            media_filesinuse($INUSE, $IMG);
1361c182313eSAndreas Gohr        } elseif($do == 'filelist') {
136200e3e394SChristopher Smith            media_filelist($NS, $AUTH, $JUMPTO,false,$sort);
1363c9f56829SAndreas Gohr        } elseif($do == 'searchlist') {
1364ac7a515fSAndreas Gohr            media_searchlist($INPUT->str('q'), $NS, $AUTH);
1365c182313eSAndreas Gohr        } else {
1366c182313eSAndreas Gohr            msg('Unknown action '.hsc($do), -1);
1367c182313eSAndreas Gohr        }
1368c182313eSAndreas Gohr    }
1369c182313eSAndreas Gohr    $evt->advise_after();
1370c182313eSAndreas Gohr    unset($evt);
1371c182313eSAndreas Gohr    if(!$fromajax) ptln('</div>');
1372c182313eSAndreas Gohr
13733df72098SAndreas Gohr}
13743df72098SAndreas Gohr
13753df72098SAndreas Gohr/**
1376d9162c6cSKate Arzamastseva * Prints the central column in full-screen media manager
1377d9162c6cSKate Arzamastseva * Depending on the opened tab this may be a list of
1378d9162c6cSKate Arzamastseva * files in a namespace, upload form or search form
1379d9162c6cSKate Arzamastseva *
1380d9162c6cSKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net>
1381d9162c6cSKate Arzamastseva */
1382035e07f1SKate Arzamastsevafunction tpl_mediaFileList() {
1383d9162c6cSKate Arzamastseva    global $AUTH;
1384d9162c6cSKate Arzamastseva    global $NS;
1385d9162c6cSKate Arzamastseva    global $JUMPTO;
138695b451bcSAdrian Lang    global $lang;
1387585bf44eSChristopher Smith    /** @var Input $INPUT */
1388ac7a515fSAndreas Gohr    global $INPUT;
1389d9162c6cSKate Arzamastseva
1390ac7a515fSAndreas Gohr    $opened_tab = $INPUT->str('tab_files');
1391e5d185e1SKate Arzamastseva    if(!$opened_tab || !in_array($opened_tab, array('files', 'upload', 'search'))) $opened_tab = 'files';
1392ac7a515fSAndreas Gohr    if($INPUT->str('mediado') == 'update') $opened_tab = 'upload';
1393d9162c6cSKate Arzamastseva
139494add303SAnika Henke    echo '<h2 class="a11y">'.$lang['mediaselect'].'</h2>'.NL;
139595b451bcSAdrian Lang
1396ed69a2aeSKate Arzamastseva    media_tabs_files($opened_tab);
139723846a98SKate Arzamastseva
139894add303SAnika Henke    echo '<div class="panelHeader">'.NL;
139995b451bcSAdrian Lang    echo '<h3>';
1400026d14a9SAnika Henke    $tabTitle = ($NS) ? $NS : '['.$lang['mediaroot'].']';
1401c98f205eSAdrian Lang    printf($lang['media_'.$opened_tab], '<strong>'.hsc($tabTitle).'</strong>');
140294add303SAnika Henke    echo '</h3>'.NL;
140395b451bcSAdrian Lang    if($opened_tab === 'search' || $opened_tab === 'files') {
140495b451bcSAdrian Lang        media_tab_files_options();
140523846a98SKate Arzamastseva    }
140694add303SAnika Henke    echo '</div>'.NL;
1407d9162c6cSKate Arzamastseva
140894add303SAnika Henke    echo '<div class="panelContent">'.NL;
140995b451bcSAdrian Lang    if($opened_tab == 'files') {
141095b451bcSAdrian Lang        media_tab_files($NS, $AUTH, $JUMPTO);
141195b451bcSAdrian Lang    } elseif($opened_tab == 'upload') {
141295b451bcSAdrian Lang        media_tab_upload($NS, $AUTH, $JUMPTO);
141395b451bcSAdrian Lang    } elseif($opened_tab == 'search') {
141495b451bcSAdrian Lang        media_tab_search($NS, $AUTH);
141595b451bcSAdrian Lang    }
141694add303SAnika Henke    echo '</div>'.NL;
1417d9162c6cSKate Arzamastseva}
1418d9162c6cSKate Arzamastseva
1419d9162c6cSKate Arzamastseva/**
1420d9162c6cSKate Arzamastseva * Prints the third column in full-screen media manager
1421d9162c6cSKate Arzamastseva * Depending on the opened tab this may be details of the
1422d9162c6cSKate Arzamastseva * selected file, the meta editing dialog or
1423d9162c6cSKate Arzamastseva * list of file revisions
1424d9162c6cSKate Arzamastseva *
1425d9162c6cSKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net>
1426d9162c6cSKate Arzamastseva */
1427035e07f1SKate Arzamastsevafunction tpl_mediaFileDetails($image, $rev) {
1428e8a2a143SMichael Hamann    global $conf, $DEL, $lang;
1429585bf44eSChristopher Smith    /** @var Input $INPUT */
1430585bf44eSChristopher Smith    global $INPUT;
1431d9162c6cSKate Arzamastseva
143292cac9a9SKate Arzamastseva    $removed = (!file_exists(mediaFN($image)) && file_exists(mediaMetaFN($image, '.changes')) && $conf['mediarevisions']);
1433ac7a515fSAndreas Gohr    if(!$image || (!file_exists(mediaFN($image)) && !$removed) || $DEL) return;
14346dd095f5SKate Arzamastseva    if($rev && !file_exists(mediaFN($image, $rev))) $rev = false;
1435e8a2a143SMichael Hamann    $ns = getNS($image);
1436ac7a515fSAndreas Gohr    $do = $INPUT->str('mediado');
14371eeeced2SKate Arzamastseva
1438ac7a515fSAndreas Gohr    $opened_tab = $INPUT->str('tab_details');
1439e5d185e1SKate Arzamastseva
1440e5d185e1SKate Arzamastseva    $tab_array = array('view');
1441ac7a515fSAndreas Gohr    list(, $mime) = mimetype($image);
1442e5d185e1SKate Arzamastseva    if($mime == 'image/jpeg') {
1443e5d185e1SKate Arzamastseva        $tab_array[] = 'edit';
1444e5d185e1SKate Arzamastseva    }
1445e5d185e1SKate Arzamastseva    if($conf['mediarevisions']) {
1446e5d185e1SKate Arzamastseva        $tab_array[] = 'history';
1447e5d185e1SKate Arzamastseva    }
1448e5d185e1SKate Arzamastseva
1449e5d185e1SKate Arzamastseva    if(!$opened_tab || !in_array($opened_tab, $tab_array)) $opened_tab = 'view';
1450ac7a515fSAndreas Gohr    if($INPUT->bool('edit')) $opened_tab = 'edit';
145123846a98SKate Arzamastseva    if($do == 'restore') $opened_tab = 'view';
1452d9162c6cSKate Arzamastseva
1453ed69a2aeSKate Arzamastseva    media_tabs_details($image, $opened_tab);
145423846a98SKate Arzamastseva
145559f3611bSAnika Henke    echo '<div class="panelHeader"><h3>';
1456ac7a515fSAndreas Gohr    list($ext) = mimetype($image, false);
145795b451bcSAdrian Lang    $class    = preg_replace('/[^_\-a-z0-9]+/i', '_', $ext);
145895b451bcSAdrian Lang    $class    = 'select mediafile mf_'.$class;
145900c2d4a9SAnika Henke    $tabTitle = '<strong><a href="'.ml($image).'" class="'.$class.'" title="'.$lang['mediaview'].'">'.$image.'</a>'.'</strong>';
146008317413SAdrian Lang    if($opened_tab === 'view' && $rev) {
146108317413SAdrian Lang        printf($lang['media_viewold'], $tabTitle, dformat($rev));
146208317413SAdrian Lang    } else {
1463026d14a9SAnika Henke        printf($lang['media_'.$opened_tab], $tabTitle);
146408317413SAdrian Lang    }
1465b8a84c03SAndreas Gohr
146694add303SAnika Henke    echo '</h3></div>'.NL;
146795b451bcSAdrian Lang
146894add303SAnika Henke    echo '<div class="panelContent">'.NL;
146995b451bcSAdrian Lang
147023846a98SKate Arzamastseva    if($opened_tab == 'view') {
1471e8a2a143SMichael Hamann        media_tab_view($image, $ns, null, $rev);
147223846a98SKate Arzamastseva
147392cac9a9SKate Arzamastseva    } elseif($opened_tab == 'edit' && !$removed) {
1474e8a2a143SMichael Hamann        media_tab_edit($image, $ns);
147523846a98SKate Arzamastseva
1476e5d185e1SKate Arzamastseva    } elseif($opened_tab == 'history' && $conf['mediarevisions']) {
1477e8a2a143SMichael Hamann        media_tab_history($image, $ns);
147823846a98SKate Arzamastseva    }
147995b451bcSAdrian Lang
148094add303SAnika Henke    echo '</div>'.NL;
1481d9162c6cSKate Arzamastseva}
1482d9162c6cSKate Arzamastseva
1483d9162c6cSKate Arzamastseva/**
14843df72098SAndreas Gohr * prints the namespace tree in the mediamanger popup
14853df72098SAndreas Gohr *
14863df72098SAndreas Gohr * Only allowed in mediamanager.php
14873df72098SAndreas Gohr *
14883df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
14893df72098SAndreas Gohr */
1490fa8e5c77SKate Arzamastsevafunction tpl_mediaTree() {
14913df72098SAndreas Gohr    global $NS;
149223846a98SKate Arzamastseva    ptln('<div id="media__tree">');
14933df72098SAndreas Gohr    media_nstree($NS);
14943df72098SAndreas Gohr    ptln('</div>');
14953df72098SAndreas Gohr}
14963df72098SAndreas Gohr
1497a00de5b5SAndreas Gohr/**
1498a00de5b5SAndreas Gohr * Print a dropdown menu with all DokuWiki actions
1499a00de5b5SAndreas Gohr *
1500a00de5b5SAndreas Gohr * Note: this will not use any pretty URLs
1501a00de5b5SAndreas Gohr *
1502a00de5b5SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
1503a00de5b5SAndreas Gohr */
1504a00de5b5SAndreas Gohrfunction tpl_actiondropdown($empty = '', $button = '&gt;') {
1505a00de5b5SAndreas Gohr    global $ID;
1506a00de5b5SAndreas Gohr    global $REV;
1507a00de5b5SAndreas Gohr    global $lang;
1508585bf44eSChristopher Smith    /** @var Input $INPUT */
1509585bf44eSChristopher Smith    global $INPUT;
1510a00de5b5SAndreas Gohr
1511e63eccffSAndreas Gohr    echo '<form action="'.script().'" method="get" accept-charset="utf-8">';
15123b9a3b55SAnika Henke    echo '<div class="no">';
1513a00de5b5SAndreas Gohr    echo '<input type="hidden" name="id" value="'.$ID.'" />';
1514a00de5b5SAndreas Gohr    if($REV) echo '<input type="hidden" name="rev" value="'.$REV.'" />';
1515585bf44eSChristopher Smith    if ($INPUT->server->str('REMOTE_USER')) {
1516a00de5b5SAndreas Gohr        echo '<input type="hidden" name="sectok" value="'.getSecurityToken().'" />';
151761efcda1SChristopher Smith    }
1518a00de5b5SAndreas Gohr
15195f17c394SAnika Henke    echo '<select name="do" class="edit quickselect" title="'.$lang['tools'].'">';
1520a00de5b5SAndreas Gohr    echo '<option value="">'.$empty.'</option>';
1521a00de5b5SAndreas Gohr
152261917024SAnika Henke    echo '<optgroup label="'.$lang['page_tools'].'">';
1523396c218fSAndreas Gohr    $act = tpl_get_action('edit');
1524396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1525a00de5b5SAndreas Gohr
1526396c218fSAndreas Gohr    $act = tpl_get_action('revert');
1527396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1528396c218fSAndreas Gohr
15293b9a3b55SAnika Henke    $act = tpl_get_action('revisions');
15303b9a3b55SAnika Henke    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
15313b9a3b55SAnika Henke
1532396c218fSAndreas Gohr    $act = tpl_get_action('backlink');
1533396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
15343b9a3b55SAnika Henke
15353b9a3b55SAnika Henke    $act = tpl_get_action('subscribe');
15363b9a3b55SAnika Henke    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1537a00de5b5SAndreas Gohr    echo '</optgroup>';
1538a00de5b5SAndreas Gohr
153961917024SAnika Henke    echo '<optgroup label="'.$lang['site_tools'].'">';
1540396c218fSAndreas Gohr    $act = tpl_get_action('recent');
1541396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1542396c218fSAndreas Gohr
15433b9a3b55SAnika Henke    $act = tpl_get_action('media');
15443b9a3b55SAnika Henke    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
15453b9a3b55SAnika Henke
1546396c218fSAndreas Gohr    $act = tpl_get_action('index');
1547396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1548a00de5b5SAndreas Gohr    echo '</optgroup>';
1549a00de5b5SAndreas Gohr
155061917024SAnika Henke    echo '<optgroup label="'.$lang['user_tools'].'">';
1551396c218fSAndreas Gohr    $act = tpl_get_action('login');
1552396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1553a00de5b5SAndreas Gohr
15543b9a3b55SAnika Henke    $act = tpl_get_action('register');
1555396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1556a00de5b5SAndreas Gohr
15573b9a3b55SAnika Henke    $act = tpl_get_action('profile');
1558396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1559a00de5b5SAndreas Gohr
1560396c218fSAndreas Gohr    $act = tpl_get_action('admin');
1561396c218fSAndreas Gohr    if($act) echo '<option value="'.$act['params']['do'].'">'.$lang['btn_'.$act['type']].'</option>';
1562a00de5b5SAndreas Gohr    echo '</optgroup>';
1563a00de5b5SAndreas Gohr
1564a00de5b5SAndreas Gohr    echo '</select>';
1565f22c1964SAndreas Gohr    echo '<input type="submit" value="'.$button.'" />';
15663b9a3b55SAnika Henke    echo '</div>';
1567a00de5b5SAndreas Gohr    echo '</form>';
1568a00de5b5SAndreas Gohr}
1569a00de5b5SAndreas Gohr
1570066fee30SAndreas Gohr/**
1571066fee30SAndreas Gohr * Print a informational line about the used license
1572066fee30SAndreas Gohr *
1573066fee30SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
1574ac7a515fSAndreas Gohr * @param  string $img     print image? (|button|badge)
1575ac7a515fSAndreas Gohr * @param  bool   $imgonly skip the textual description?
1576ac7a515fSAndreas Gohr * @param  bool   $return  when true don't print, but return HTML
1577ac7a515fSAndreas Gohr * @param  bool   $wrap    wrap in div with class="license"?
1578ac7a515fSAndreas Gohr * @return string
1579066fee30SAndreas Gohr */
158080083a41SAndreas Gohrfunction tpl_license($img = 'badge', $imgonly = false, $return = false, $wrap = true) {
1581066fee30SAndreas Gohr    global $license;
1582066fee30SAndreas Gohr    global $conf;
1583066fee30SAndreas Gohr    global $lang;
1584066fee30SAndreas Gohr    if(!$conf['license']) return '';
1585066fee30SAndreas Gohr    if(!is_array($license[$conf['license']])) return '';
1586066fee30SAndreas Gohr    $lic    = $license[$conf['license']];
158753e15c8bSAnika Henke    $target = ($conf['target']['extern']) ? ' target="'.$conf['target']['extern'].'"' : '';
1588066fee30SAndreas Gohr
158980083a41SAndreas Gohr    $out = '';
159080083a41SAndreas Gohr    if($wrap) $out .= '<div class="license">';
1591066fee30SAndreas Gohr    if($img) {
1592066fee30SAndreas Gohr        $src = license_img($img);
1593066fee30SAndreas Gohr        if($src) {
159453e15c8bSAnika Henke            $out .= '<a href="'.$lic['url'].'" rel="license"'.$target;
159553e15c8bSAnika Henke            $out .= '><img src="'.DOKU_BASE.$src.'" alt="'.$lic['name'].'" /></a>';
159653e15c8bSAnika Henke            if(!$imgonly) $out .= ' ';
1597066fee30SAndreas Gohr        }
1598066fee30SAndreas Gohr    }
15994cefd216SMichael Klier    if(!$imgonly) {
160053e15c8bSAnika Henke        $out .= $lang['license'].' ';
1601d317fb5dSAnika Henke        $out .= '<bdi><a href="'.$lic['url'].'" rel="license" class="urlextern"'.$target;
1602d317fb5dSAnika Henke        $out .= '>'.$lic['name'].'</a></bdi>';
16034cefd216SMichael Klier    }
160480083a41SAndreas Gohr    if($wrap) $out .= '</div>';
1605066fee30SAndreas Gohr
1606066fee30SAndreas Gohr    if($return) return $out;
1607066fee30SAndreas Gohr    echo $out;
1608ac7a515fSAndreas Gohr    return '';
1609066fee30SAndreas Gohr}
1610066fee30SAndreas Gohr
1611a81910eeSAndreas Gohr/**
1612835dfcaeSAnika Henke * Includes the rendered HTML of a given page
1613a81910eeSAndreas Gohr *
1614a81910eeSAndreas Gohr * This function is useful to populate sidebars or similar features in a
1615a81910eeSAndreas Gohr * template
1616a81910eeSAndreas Gohr */
1617835dfcaeSAnika Henkefunction tpl_include_page($pageid, $print = true, $propagate = false) {
1618c786a1b6SAnika Henke    if (!$pageid) return false;
1619835dfcaeSAnika Henke    if ($propagate) $pageid = page_findnearest($pageid);
1620835dfcaeSAnika Henke
1621c786a1b6SAnika Henke    global $TOC;
16229a2e250aSAndreas Gohr    $oldtoc = $TOC;
1623a81910eeSAndreas Gohr    $html   = p_wiki_xhtml($pageid, '', false);
16249a2e250aSAndreas Gohr    $TOC    = $oldtoc;
1625a81910eeSAndreas Gohr
1626a81910eeSAndreas Gohr    if(!$print) return $html;
1627a81910eeSAndreas Gohr    echo $html;
1628e66d3e6dSAndreas Gohr    return $html;
1629e66d3e6dSAndreas Gohr}
1630e66d3e6dSAndreas Gohr
1631e66d3e6dSAndreas Gohr/**
16325b75cd1fSAdrian Lang * Display the subscribe form
16335b75cd1fSAdrian Lang *
16345b75cd1fSAdrian Lang * @author Adrian Lang <lang@cosmocode.de>
16355b75cd1fSAdrian Lang */
16365b75cd1fSAdrian Langfunction tpl_subscribe() {
16375b75cd1fSAdrian Lang    global $INFO;
16385b75cd1fSAdrian Lang    global $ID;
16395b75cd1fSAdrian Lang    global $lang;
16406b8f02cfSAdrian Lang    global $conf;
164140c347dbSAdrian Lang    $stime_days = $conf['subscribe_time'] / 60 / 60 / 24;
16425b75cd1fSAdrian Lang
16435b75cd1fSAdrian Lang    echo p_locale_xhtml('subscr_form');
16445b75cd1fSAdrian Lang    echo '<h2>'.$lang['subscr_m_current_header'].'</h2>';
164515741132SAndreas Gohr    echo '<div class="level2">';
16465b75cd1fSAdrian Lang    if($INFO['subscribed'] === false) {
16475b75cd1fSAdrian Lang        echo '<p>'.$lang['subscr_m_not_subscribed'].'</p>';
16485b75cd1fSAdrian Lang    } else {
16495b75cd1fSAdrian Lang        echo '<ul>';
16505b75cd1fSAdrian Lang        foreach($INFO['subscribed'] as $sub) {
1651056c2049SAndreas Gohr            echo '<li><div class="li">';
16525b75cd1fSAdrian Lang            if($sub['target'] !== $ID) {
1653056c2049SAndreas Gohr                echo '<code class="ns">'.hsc(prettyprint_id($sub['target'])).'</code>';
16545b75cd1fSAdrian Lang            } else {
1655056c2049SAndreas Gohr                echo '<code class="page">'.hsc(prettyprint_id($sub['target'])).'</code>';
16565b75cd1fSAdrian Lang            }
165740c347dbSAdrian Lang            $sstl = sprintf($lang['subscr_style_'.$sub['style']], $stime_days);
165815741132SAndreas Gohr            if(!$sstl) $sstl = hsc($sub['style']);
1659056c2049SAndreas Gohr            echo ' ('.$sstl.') ';
166015741132SAndreas Gohr
1661ac7a515fSAndreas Gohr            echo '<a href="'.wl(
1662ac7a515fSAndreas Gohr                $ID,
1663ac7a515fSAndreas Gohr                array(
1664ac7a515fSAndreas Gohr                     'do'        => 'subscribe',
166566d2bed9SAdrian Lang                     'sub_target'=> $sub['target'],
166666d2bed9SAdrian Lang                     'sub_style' => $sub['style'],
166766d2bed9SAdrian Lang                     'sub_action'=> 'unsubscribe',
1668ac7a515fSAndreas Gohr                     'sectok'    => getSecurityToken()
1669ac7a515fSAndreas Gohr                )
1670ac7a515fSAndreas Gohr            ).
167166d2bed9SAdrian Lang                '" class="unsubscribe">'.$lang['subscr_m_unsubscribe'].
167266d2bed9SAdrian Lang                '</a></div></li>';
16735b75cd1fSAdrian Lang        }
16745b75cd1fSAdrian Lang        echo '</ul>';
16755b75cd1fSAdrian Lang    }
167615741132SAndreas Gohr    echo '</div>';
16775b75cd1fSAdrian Lang
167815741132SAndreas Gohr    // Add new subscription form
16795b75cd1fSAdrian Lang    echo '<h2>'.$lang['subscr_m_new_header'].'</h2>';
168015741132SAndreas Gohr    echo '<div class="level2">';
16815b75cd1fSAdrian Lang    $ns      = getNS($ID).':';
168215741132SAndreas Gohr    $targets = array(
168315741132SAndreas Gohr        $ID => '<code class="page">'.prettyprint_id($ID).'</code>',
168415741132SAndreas Gohr        $ns => '<code class="ns">'.prettyprint_id($ns).'</code>',
168515741132SAndreas Gohr    );
168615741132SAndreas Gohr    $styles  = array(
168715741132SAndreas Gohr        'every'  => $lang['subscr_style_every'],
16886b8f02cfSAdrian Lang        'digest' => sprintf($lang['subscr_style_digest'], $stime_days),
16896b8f02cfSAdrian Lang        'list'   => sprintf($lang['subscr_style_list'], $stime_days),
169015741132SAndreas Gohr    );
169115741132SAndreas Gohr
1692056c2049SAndreas Gohr    $form = new Doku_Form(array('id' => 'subscribe__form'));
1693056c2049SAndreas Gohr    $form->startFieldset($lang['subscr_m_subscribe']);
1694056c2049SAndreas Gohr    $form->addRadioSet('sub_target', $targets);
1695056c2049SAndreas Gohr    $form->startFieldset($lang['subscr_m_receive']);
1696056c2049SAndreas Gohr    $form->addRadioSet('sub_style', $styles);
1697056c2049SAndreas Gohr    $form->addHidden('sub_action', 'subscribe');
1698056c2049SAndreas Gohr    $form->addHidden('do', 'subscribe');
1699056c2049SAndreas Gohr    $form->addHidden('id', $ID);
1700056c2049SAndreas Gohr    $form->endFieldset();
17015b75cd1fSAdrian Lang    $form->addElement(form_makeButton('submit', 'subscribe', $lang['subscr_m_subscribe']));
17025b75cd1fSAdrian Lang    html_form('SUBSCRIBE', $form);
170315741132SAndreas Gohr    echo '</div>';
17045b75cd1fSAdrian Lang}
17055b75cd1fSAdrian Lang
1706d059ba9bSAndreas Gohr/**
1707d059ba9bSAndreas Gohr * Tries to send already created content right to the browser
1708d059ba9bSAndreas Gohr *
1709d059ba9bSAndreas Gohr * Wraps around ob_flush() and flush()
1710d059ba9bSAndreas Gohr *
1711d059ba9bSAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
1712d059ba9bSAndreas Gohr */
1713d059ba9bSAndreas Gohrfunction tpl_flush() {
1714d059ba9bSAndreas Gohr    ob_flush();
1715d059ba9bSAndreas Gohr    flush();
1716d059ba9bSAndreas Gohr}
1717d059ba9bSAndreas Gohr
1718afca7e7eSAnika Henke/**
1719378325f9SAndreas Gohr * Tries to find a ressource file in the given locations.
1720afca7e7eSAnika Henke *
1721378325f9SAndreas Gohr * If a given location starts with a colon it is assumed to be a media
1722378325f9SAndreas Gohr * file, otherwise it is assumed to be relative to the current template
1723378325f9SAndreas Gohr *
1724378325f9SAndreas Gohr * @param  array $search       locations to look at
1725378325f9SAndreas Gohr * @param  bool  $abs           if to use absolute URL
1726ac7a515fSAndreas Gohr * @param  array &$imginfo   filled with getimagesize()
1727ac7a515fSAndreas Gohr * @return string
1728378325f9SAndreas Gohr * @author Andreas  Gohr <andi@splitbrain.org>
1729afca7e7eSAnika Henke */
1730378325f9SAndreas Gohrfunction tpl_getMediaFile($search, $abs = false, &$imginfo = null) {
1731ac7a515fSAndreas Gohr    $img     = '';
1732ac7a515fSAndreas Gohr    $file    = '';
1733ac7a515fSAndreas Gohr    $ismedia = false;
1734378325f9SAndreas Gohr    // loop through candidates until a match was found:
1735378325f9SAndreas Gohr    foreach($search as $img) {
1736378325f9SAndreas Gohr        if(substr($img, 0, 1) == ':') {
1737378325f9SAndreas Gohr            $file    = mediaFN($img);
1738378325f9SAndreas Gohr            $ismedia = true;
1739378325f9SAndreas Gohr        } else {
1740c4766956SAndreas Gohr            $file    = tpl_incdir().$img;
1741378325f9SAndreas Gohr            $ismedia = false;
17421f13e33dSAnika Henke        }
17430f747863Slupo49
1744378325f9SAndreas Gohr        if(file_exists($file)) break;
1745872a6d29SAnika Henke    }
1746378325f9SAndreas Gohr
1747378325f9SAndreas Gohr    // fetch image data if requested
1748378325f9SAndreas Gohr    if(!is_null($imginfo)) {
1749378325f9SAndreas Gohr        $imginfo = getimagesize($file);
1750378325f9SAndreas Gohr    }
1751378325f9SAndreas Gohr
1752378325f9SAndreas Gohr    // build URL
1753378325f9SAndreas Gohr    if($ismedia) {
1754378325f9SAndreas Gohr        $url = ml($img, '', true, '', $abs);
1755378325f9SAndreas Gohr    } else {
1756c4766956SAndreas Gohr        $url = tpl_basedir().$img;
1757378325f9SAndreas Gohr        if($abs) $url = DOKU_URL.substr($url, strlen(DOKU_REL));
1758378325f9SAndreas Gohr    }
1759378325f9SAndreas Gohr
1760378325f9SAndreas Gohr    return $url;
1761a7e5f74cSlupo49}
17621f13e33dSAnika Henke
1763872a6d29SAnika Henke/**
1764e5d4768dSAndreas Gohr * PHP include a file
1765e5d4768dSAndreas Gohr *
1766e5d4768dSAndreas Gohr * either from the conf directory if it exists, otherwise use
1767e5d4768dSAndreas Gohr * file in the template's root directory.
1768e5d4768dSAndreas Gohr *
1769e5d4768dSAndreas Gohr * The function honours config cascade settings and looks for the given
1770e5d4768dSAndreas Gohr * file next to the ´main´ config files, in the order protected, local,
1771e5d4768dSAndreas Gohr * default.
1772e5d4768dSAndreas Gohr *
1773e5d4768dSAndreas Gohr * Note: no escaping or sanity checking is done here. Never pass user input
1774e5d4768dSAndreas Gohr * to this function!
1775e5d4768dSAndreas Gohr *
1776e5d4768dSAndreas Gohr * @author Anika Henke <anika@selfthinker.org>
1777e5d4768dSAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org>
1778e5d4768dSAndreas Gohr */
1779e5d4768dSAndreas Gohrfunction tpl_includeFile($file) {
1780e5d4768dSAndreas Gohr    global $config_cascade;
1781e5d4768dSAndreas Gohr    foreach(array('protected', 'local', 'default') as $config_group) {
1782e5d4768dSAndreas Gohr        if(empty($config_cascade['main'][$config_group])) continue;
1783e5d4768dSAndreas Gohr        foreach($config_cascade['main'][$config_group] as $conf_file) {
1784e5d4768dSAndreas Gohr            $dir = dirname($conf_file);
1785e5d4768dSAndreas Gohr            if(file_exists("$dir/$file")) {
1786f3a1225fSAnika Henke                include("$dir/$file");
1787e5d4768dSAndreas Gohr                return;
1788e5d4768dSAndreas Gohr            }
1789e5d4768dSAndreas Gohr        }
1790e5d4768dSAndreas Gohr    }
1791e5d4768dSAndreas Gohr
1792e5d4768dSAndreas Gohr    // still here? try the template dir
1793e5d4768dSAndreas Gohr    $file = tpl_incdir().$file;
1794e5d4768dSAndreas Gohr    if(file_exists($file)) {
1795f3a1225fSAnika Henke        include($file);
1796e5d4768dSAndreas Gohr    }
1797e5d4768dSAndreas Gohr}
1798e5d4768dSAndreas Gohr
1799e5d4768dSAndreas Gohr/**
1800872a6d29SAnika Henke * Returns <link> tag for various icon types (favicon|mobile|generic)
1801872a6d29SAnika Henke *
1802872a6d29SAnika Henke * @author Anika Henke <anika@selfthinker.org>
1803ac7a515fSAndreas Gohr * @param  array $types - list of icon types to display (favicon|mobile|generic)
1804ac7a515fSAndreas Gohr * @return string
1805872a6d29SAnika Henke */
1806872a6d29SAnika Henkefunction tpl_favicon($types = array('favicon')) {
1807872a6d29SAnika Henke
1808872a6d29SAnika Henke    $return = '';
1809872a6d29SAnika Henke
1810872a6d29SAnika Henke    foreach($types as $type) {
1811872a6d29SAnika Henke        switch($type) {
1812872a6d29SAnika Henke            case 'favicon':
1813378325f9SAndreas Gohr                $look = array(':wiki:favicon.ico', ':favicon.ico', 'images/favicon.ico');
1814378325f9SAndreas Gohr                $return .= '<link rel="shortcut icon" href="'.tpl_getMediaFile($look).'" />'.NL;
1815872a6d29SAnika Henke                break;
1816872a6d29SAnika Henke            case 'mobile':
1817cab75975SAnika Henke                $look = array(':wiki:apple-touch-icon.png', ':apple-touch-icon.png', 'images/apple-touch-icon.png');
1818378325f9SAndreas Gohr                $return .= '<link rel="apple-touch-icon" href="'.tpl_getMediaFile($look).'" />'.NL;
1819872a6d29SAnika Henke                break;
1820872a6d29SAnika Henke            case 'generic':
1821872a6d29SAnika Henke                // ideal world solution, which doesn't work in any browser yet
1822378325f9SAndreas Gohr                $look = array(':wiki:favicon.svg', ':favicon.svg', 'images/favicon.svg');
1823378325f9SAndreas Gohr                $return .= '<link rel="icon" href="'.tpl_getMediaFile($look).'" type="image/svg+xml" />'.NL;
1824872a6d29SAnika Henke                break;
1825872a6d29SAnika Henke        }
1826872a6d29SAnika Henke    }
1827872a6d29SAnika Henke
1828872a6d29SAnika Henke    return $return;
1829afca7e7eSAnika Henke}
1830afca7e7eSAnika Henke
1831d9162c6cSKate Arzamastseva/**
1832d9162c6cSKate Arzamastseva * Prints full-screen media manager
1833d9162c6cSKate Arzamastseva *
1834d9162c6cSKate Arzamastseva * @author Kate Arzamastseva <pshns@ukr.net>
1835d9162c6cSKate Arzamastseva */
1836d9162c6cSKate Arzamastsevafunction tpl_media() {
1837ac7a515fSAndreas Gohr    global $NS, $IMG, $JUMPTO, $REV, $lang, $fullscreen, $INPUT;
183888a71175SKate Arzamastseva    $fullscreen = true;
183995b451bcSAdrian Lang    require_once DOKU_INC.'lib/exe/mediamanager.php';
1840d9162c6cSKate Arzamastseva
1841ac7a515fSAndreas Gohr    $rev   = '';
1842ac7a515fSAndreas Gohr    $image = cleanID($INPUT->str('image'));
184398f03b57SKate Arzamastseva    if(isset($IMG)) $image = $IMG;
184498f03b57SKate Arzamastseva    if(isset($JUMPTO)) $image = $JUMPTO;
18459c1bd4bcSKate Arzamastseva    if(isset($REV) && !$JUMPTO) $rev = $REV;
184698f03b57SKate Arzamastseva
184794add303SAnika Henke    echo '<div id="mediamanager__page">'.NL;
1848bc314c58SAnika Henke    echo '<h1>'.$lang['btn_media'].'</h1>'.NL;
1849d9162c6cSKate Arzamastseva    html_msgarea();
185094add303SAnika Henke
185194add303SAnika Henke    echo '<div class="panel namespaces">'.NL;
185294add303SAnika Henke    echo '<h2>'.$lang['namespaces'].'</h2>'.NL;
185395b451bcSAdrian Lang    echo '<div class="panelHeader">';
1854ba340a70SAnika Henke    echo $lang['media_namespaces'];
185594add303SAnika Henke    echo '</div>'.NL;
185695b451bcSAdrian Lang
185794add303SAnika Henke    echo '<div class="panelContent" id="media__tree">'.NL;
185895b451bcSAdrian Lang    media_nstree($NS);
185994add303SAnika Henke    echo '</div>'.NL;
186094add303SAnika Henke    echo '</div>'.NL;
1861fa8e5c77SKate Arzamastseva
186294add303SAnika Henke    echo '<div class="panel filelist">'.NL;
1863035e07f1SKate Arzamastseva    tpl_mediaFileList();
186494add303SAnika Henke    echo '</div>'.NL;
1865fa8e5c77SKate Arzamastseva
186694add303SAnika Henke    echo '<div class="panel file">'.NL;
186794add303SAnika Henke    echo '<h2 class="a11y">'.$lang['media_file'].'</h2>'.NL;
1868035e07f1SKate Arzamastseva    tpl_mediaFileDetails($image, $rev);
186994add303SAnika Henke    echo '</div>'.NL;
1870ba340a70SAnika Henke
187194add303SAnika Henke    echo '</div>'.NL;
1872d9162c6cSKate Arzamastseva}
1873afca7e7eSAnika Henke
1874c71db656SAnika Henke/**
1875c71db656SAnika Henke * Return useful layout classes
1876c71db656SAnika Henke *
1877c71db656SAnika Henke * @author Anika Henke <anika@selfthinker.org>
1878c71db656SAnika Henke */
1879c71db656SAnika Henkefunction tpl_classes() {
1880c71db656SAnika Henke    global $ACT, $conf, $ID, $INFO;
1881585bf44eSChristopher Smith    /** @var Input $INPUT */
1882585bf44eSChristopher Smith    global $INPUT;
1883585bf44eSChristopher Smith
1884c71db656SAnika Henke    $classes = array(
1885c71db656SAnika Henke        'dokuwiki',
1886c71db656SAnika Henke        'mode_'.$ACT,
1887c71db656SAnika Henke        'tpl_'.$conf['template'],
1888585bf44eSChristopher Smith        $INPUT->server->bool('REMOTE_USER') ? 'loggedIn' : '',
188939f00629SAnika Henke        $INFO['exists'] ? '' : 'notFound',
1890c71db656SAnika Henke        ($ID == $conf['start']) ? 'home' : '',
1891c71db656SAnika Henke    );
1892c71db656SAnika Henke    return join(' ', $classes);
1893c71db656SAnika Henke}
1894c71db656SAnika Henke
1895e3776c06SMichael Hamann//Setup VIM: ex: et ts=4 :
1896a00de5b5SAndreas Gohr
1897