xref: /dokuwiki/inc/template.php (revision 6b13307fb447795714d01cdc029d6ed7ac087cf3)
1*6b13307fSandi<?php
2*6b13307fSandi/**
3*6b13307fSandi * DokuWiki template functions
4*6b13307fSandi *
5*6b13307fSandi * @license    GPL 2 (http://www.gnu.org/licenses/gpl.html)
6*6b13307fSandi * @author     Andreas Gohr <andi@splitbrain.org>
7*6b13307fSandi */
8*6b13307fSandi
9*6b13307fSandi  if(!defined('DOKU_INC')) define('DOKU_INC',realpath(dirname(__FILE__).'/../').'/');
10*6b13307fSandi  require_once(DOKU_INC.'conf/dokuwiki.php');
11*6b13307fSandi
12*6b13307fSandi/**
13*6b13307fSandi * Wrapper around htmlspecialchars()
14*6b13307fSandi *
15*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
16*6b13307fSandi * @see    htmlspecialchars()
17*6b13307fSandi */
18*6b13307fSandifunction hsc($string){
19*6b13307fSandi  return htmlspecialchars($string);
20*6b13307fSandi}
21*6b13307fSandi
22*6b13307fSandi/**
23*6b13307fSandi * print a newline terminated string
24*6b13307fSandi *
25*6b13307fSandi * You can give an indention as optional parameter
26*6b13307fSandi *
27*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
28*6b13307fSandi */
29*6b13307fSandifunction ptln($string,$intend=0){
30*6b13307fSandi  for($i=0; $i<$intend; $i++) print ' ';
31*6b13307fSandi  print"$string\n";
32*6b13307fSandi}
33*6b13307fSandi
34*6b13307fSandi/**
35*6b13307fSandi * Print the content
36*6b13307fSandi *
37*6b13307fSandi * This function is used for printing all the usual content
38*6b13307fSandi * (defined by the global $ACT var) by calling the appropriate
39*6b13307fSandi * outputfunction(s) from html.php
40*6b13307fSandi *
41*6b13307fSandi * Everything that doesn't use the default template isn't
42*6b13307fSandi * handled by this function. ACL stuff is not done either.
43*6b13307fSandi *
44*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
45*6b13307fSandi */
46*6b13307fSandifunction tpl_content(){
47*6b13307fSandi  global $ACT;
48*6b13307fSandi  global $TEXT;
49*6b13307fSandi  global $PRE;
50*6b13307fSandi  global $SUF;
51*6b13307fSandi  global $SUM;
52*6b13307fSandi  global $IDX;
53*6b13307fSandi  global $lang;
54*6b13307fSandi
55*6b13307fSandi  switch($ACT){
56*6b13307fSandi    case 'show':
57*6b13307fSandi      html_show();
58*6b13307fSandi      break;
59*6b13307fSandi    case $lang['btn_preview']:
60*6b13307fSandi      html_edit($TEXT);
61*6b13307fSandi      html_show($TEXT);
62*6b13307fSandi      break;
63*6b13307fSandi    case 'edit':
64*6b13307fSandi      html_edit();
65*6b13307fSandi      break;
66*6b13307fSandi    case 'wordblock':
67*6b13307fSandi      html_edit($TEXT,'wordblock');
68*6b13307fSandi      break;
69*6b13307fSandi    case 'search':
70*6b13307fSandi      html_search();
71*6b13307fSandi      break;
72*6b13307fSandi    case 'revisions':
73*6b13307fSandi      html_revisions();
74*6b13307fSandi      break;
75*6b13307fSandi    case 'diff':
76*6b13307fSandi      html_diff();
77*6b13307fSandi      break;
78*6b13307fSandi    case 'recent':
79*6b13307fSandi      html_recent();
80*6b13307fSandi      break;
81*6b13307fSandi    case 'index':
82*6b13307fSandi      html_index($IDX); #FIXME can this be pulled from globals? is it sanitized correctly?
83*6b13307fSandi      break;
84*6b13307fSandi    case 'backlink':
85*6b13307fSandi      html_backlinks();
86*6b13307fSandi      break;
87*6b13307fSandi    case 'conflict':
88*6b13307fSandi      html_conflict(con($PRE,$TEXT,$SUF),$SUM);
89*6b13307fSandi      html_diff(con($PRE,$TEXT,$SUF),false);
90*6b13307fSandi      break;
91*6b13307fSandi    case 'locked':
92*6b13307fSandi      html_locked($lockedby);
93*6b13307fSandi      break;
94*6b13307fSandi    case 'login':
95*6b13307fSandi      html_login();
96*6b13307fSandi      break;
97*6b13307fSandi    case 'register':
98*6b13307fSandi      #FIXME check for $conf['openregister']) needs to be done first!!
99*6b13307fSandi      html_register();
100*6b13307fSandi      break;
101*6b13307fSandi    default:
102*6b13307fSandi      print "Uhm... Where am I? This shouldn't happen";
103*6b13307fSandi  }
104*6b13307fSandi}
105*6b13307fSandi
106*6b13307fSandi
107*6b13307fSandi
108*6b13307fSandi/**
109*6b13307fSandi * Print the correct HTML meta headers
110*6b13307fSandi *
111*6b13307fSandi * This has to go into the head section of your template.
112*6b13307fSandi *
113*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
114*6b13307fSandi */
115*6b13307fSandifunction tpl_metaheaders(){
116*6b13307fSandi  global $ID;
117*6b13307fSandi  global $INFO;
118*6b13307fSandi  global $ACT;
119*6b13307fSandi  global $lang;
120*6b13307fSandi  $it=2;
121*6b13307fSandi
122*6b13307fSandi  // the usual stuff
123*6b13307fSandi  ptln('<meta name="generator" content="DokuWiki '.getVersion().'" />',$it);
124*6b13307fSandi  ptln('<link rel="start" href="'.DOKU_BASE.'" />',$it);
125*6b13307fSandi  ptln('<link rel="contents" href="'.wl($ID,'do=index').'" title="'.$lang['index'].'" />',$it);
126*6b13307fSandi  ptln('<link rel="alternate" type="application/rss+xml" title="Recent Changes" href="'.DOKU_BASE.'feed.php" />',$it);
127*6b13307fSandi  ptln('<link rel="alternate" type="application/rss+xml" title="Current Namespace" href="'.DOKU_BASE.'feed.php?mode=list&amp;ns='.$INFO['namespace'].'" />',$it);
128*6b13307fSandi  ptln('<link rel="alternate" type="text/html" title="Plain HTML" href="'.wl($ID,'do=export_html').'" />',$it);
129*6b13307fSandi  ptln('<link rel="alternate" type="text/plain" title="Wiki Markup" href="'.wl($ID, 'do=export_raw').'" />',$it);
130*6b13307fSandi  ptln('<link rel="stylesheet" media="screen" type="text/css" href="'.DOKU_BASE.'style.css" />',$it);
131*6b13307fSandi
132*6b13307fSandi  // setup robot tags apropriate for different modes
133*6b13307fSandi  if( ($ACT=='show' || $ACT=='export_html') && !$REV){
134*6b13307fSandi    if($INFO['exists']){
135*6b13307fSandi      ptln('<meta name="date" content="'.date('Y-m-d\TH:i:sO',$INFO['lastmod']).'" />',$it);
136*6b13307fSandi      //delay indexing:
137*6b13307fSandi      if((time() - $INFO['lastmod']) >= $conf['indexdelay']){
138*6b13307fSandi        ptln('<meta name="robots" content="index,follow" />',$it);
139*6b13307fSandi      }else{
140*6b13307fSandi        ptln('<meta name="robots" content="noindex,nofollow" />',$it);
141*6b13307fSandi      }
142*6b13307fSandi    }else{
143*6b13307fSandi      ptln('<meta name="robots" content="noindex,follow" />',$it);
144*6b13307fSandi    }
145*6b13307fSandi  }else{
146*6b13307fSandi    ptln('<meta name="robots" content="noindex,nofollow" />',$it);
147*6b13307fSandi  }
148*6b13307fSandi
149*6b13307fSandi  // include some JavaScript language strings
150*6b13307fSandi  ptln('<script language="JavaScript" type="text/javascript">',$it);
151*6b13307fSandi  ptln("  var alertText   = '".$lang['qb_alert']."'",$it);
152*6b13307fSandi  ptln("  var notSavedYet = '".$lang['notsavedyet']."'",$it);
153*6b13307fSandi  ptln("  var DOKU_BASE   = '".DOKU_BASE."'",$it);
154*6b13307fSandi  ptln('</script>',$it);
155*6b13307fSandi
156*6b13307fSandi  // load the default JavaScript file
157*6b13307fSandi  ptln('<script language="JavaScript" type="text/javascript" src="'.DOKU_BASE.'script.js"></script>',$it);
158*6b13307fSandi
159*6b13307fSandi
160*6b13307fSandi  //FIXME include some default CSS ? IE FIX?
161*6b13307fSandi}
162*6b13307fSandi
163*6b13307fSandi/**
164*6b13307fSandi * Print a link
165*6b13307fSandi *
166*6b13307fSandi * Just builds a link but adds additional JavaScript needed for
167*6b13307fSandi * the unsaved data check needed in the edit form.
168*6b13307fSandi *
169*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
170*6b13307fSandi */
171*6b13307fSandifunction tpl_link($url,$name,$more=''){
172*6b13307fSandi  print '<a href="'.$url.'" onclick="return svchk()" onkeypress="return svchk()"';
173*6b13307fSandi  if ($more) print ' '.$more;
174*6b13307fSandi  print ">$name</a>";
175*6b13307fSandi}
176*6b13307fSandi
177*6b13307fSandi/**
178*6b13307fSandi * Print one of the buttons
179*6b13307fSandi *
180*6b13307fSandi * Available Buttons are
181*6b13307fSandi *
182*6b13307fSandi *  edit    - edit/create/show button
183*6b13307fSandi *  history - old revisions
184*6b13307fSandi *  recent  - recent changes
185*6b13307fSandi *  login   - login/logout button - if ACL enabled
186*6b13307fSandi *  index   - The index
187*6b13307fSandi *  top     - a back to top button
188*6b13307fSandi *
189*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
190*6b13307fSandi */
191*6b13307fSandifunction tpl_button($type){
192*6b13307fSandi  global $ID;
193*6b13307fSandi  global $conf;
194*6b13307fSandi
195*6b13307fSandi  switch($type){
196*6b13307fSandi    case 'edit':
197*6b13307fSandi      print html_editbutton();
198*6b13307fSandi      break;
199*6b13307fSandi    case 'history':
200*6b13307fSandi      print html_btn(revs,$ID,'o',array('do' => 'revisions'));
201*6b13307fSandi      break;
202*6b13307fSandi    case 'recent':
203*6b13307fSandi      print html_btn(recent,'','r',array('do' => 'recent'));
204*6b13307fSandi      break;
205*6b13307fSandi    case 'index':
206*6b13307fSandi      print html_btn(index,$ID,'x',array('do' => 'index'));
207*6b13307fSandi      break;
208*6b13307fSandi    case 'top':
209*6b13307fSandi      print html_topbtn();
210*6b13307fSandi      break;
211*6b13307fSandi    case 'login':
212*6b13307fSandi      if($conf['useacl']){
213*6b13307fSandi        if($_SERVER['REMOTE_USER']){
214*6b13307fSandi          print html_btn('logout',$ID,'',array('do' => 'logout',));
215*6b13307fSandi        }else{
216*6b13307fSandi          print html_btn('login',$ID,'',array('do' => 'login'));
217*6b13307fSandi        }
218*6b13307fSandi      }
219*6b13307fSandi      break;
220*6b13307fSandi  }
221*6b13307fSandi}
222*6b13307fSandi
223*6b13307fSandi/**
224*6b13307fSandi * Print the search form
225*6b13307fSandi *
226*6b13307fSandi * @todo   svcheck missing
227*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
228*6b13307fSandi */
229*6b13307fSandifunction tpl_searchform(){
230*6b13307fSandi  global $lang;
231*6b13307fSandi  print '<form action="'.wl().'" accept-charset="utf-8" class="search">';
232*6b13307fSandi  print '<input type="hidden" name="do" value="search" />';
233*6b13307fSandi  print '<input type="text" accesskey="f" name="id" class="edit" />';
234*6b13307fSandi  print '<input type="submit" value="'.$lang['btn_search'].'" class="button" />';
235*6b13307fSandi  print '</form>';
236*6b13307fSandi}
237*6b13307fSandi
238*6b13307fSandi/**
239*6b13307fSandi * Print the breadcrumbs trace
240*6b13307fSandi *
241*6b13307fSandi * @todo   add a hierachical breadcrumb function
242*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
243*6b13307fSandi */
244*6b13307fSandifunction tpl_breadcrumbs(){
245*6b13307fSandi  global $lang;
246*6b13307fSandi  global $conf;
247*6b13307fSandi
248*6b13307fSandi  //check if enabled
249*6b13307fSandi  if(!$conf['breadcrumbs']) return;
250*6b13307fSandi
251*6b13307fSandi  $crumbs = breadcrumbs(); //setup crumb trace
252*6b13307fSandi  print $lang['breadcrumb'].':';
253*6b13307fSandi  foreach ($crumbs as $crumb){
254*6b13307fSandi    print ' &raquo; ';
255*6b13307fSandi    tpl_link(wl($crumb),noNS($crumb),'class="breadcrumbs" title="'.$crumb.'"');
256*6b13307fSandi  }
257*6b13307fSandi}
258*6b13307fSandi
259*6b13307fSandi/**
260*6b13307fSandi * Print info if the user is logged in
261*6b13307fSandi *
262*6b13307fSandi * Could be enhanced with a profile link in future?
263*6b13307fSandi *
264*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
265*6b13307fSandi */
266*6b13307fSandifunction tpl_userinfo(){
267*6b13307fSandi  global $lang;
268*6b13307fSandi  if($_SERVER['REMOTE_USER'])
269*6b13307fSandi    print $lang['loggedinas'].': '.$_SERVER['REMOTE_USER'];
270*6b13307fSandi}
271*6b13307fSandi
272*6b13307fSandi/**
273*6b13307fSandi * Print some info about the current page
274*6b13307fSandi *
275*6b13307fSandi * @author Andreas Gohr <andi@splitbrain.org>
276*6b13307fSandi */
277*6b13307fSandifunction tpl_pageinfo(){
278*6b13307fSandi  global $conf;
279*6b13307fSandi  global $lang;
280*6b13307fSandi  global $INFO;
281*6b13307fSandi  global $REV;
282*6b13307fSandi
283*6b13307fSandi  // prepare date and path
284*6b13307fSandi  $fn = $INFO['filepath'];
285*6b13307fSandi  if(!$conf['fullpath']){
286*6b13307fSandi    if($REV){
287*6b13307fSandi      $fn = str_replace(realpath($conf['olddir']).DIRECTORY_SEPARATOR,'',$fn);
288*6b13307fSandi    }else{
289*6b13307fSandi      $fn = str_replace(realpath($conf['datadir']).DIRECTORY_SEPARATOR,'',$fn);
290*6b13307fSandi    }
291*6b13307fSandi  }
292*6b13307fSandi  $date = date($conf['dformat'],$INFO['lastmod']);
293*6b13307fSandi
294*6b13307fSandi  // print it
295*6b13307fSandi  if($INFO['exists']){
296*6b13307fSandi    print $fn;
297*6b13307fSandi    print ' &middot; ';
298*6b13307fSandi    print $lang['lastmod'];
299*6b13307fSandi    print ': ';
300*6b13307fSandi    print $date;
301*6b13307fSandi    if($INFO['editor']){
302*6b13307fSandi      print ' '.$lang['by'].' ';
303*6b13307fSandi      print $INFO['editor'];
304*6b13307fSandi    }
305*6b13307fSandi    if($INFO['locked']){
306*6b13307fSandi      print ' &middot; ';
307*6b13307fSandi      print $lang['lockedby'];
308*6b13307fSandi      print ': ';
309*6b13307fSandi      print $INFO['locked'];
310*6b13307fSandi    }
311*6b13307fSandi  }
312*6b13307fSandi}
313*6b13307fSandi
314*6b13307fSandi?>
315