html.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. /**
  3. * html.php
  4. *
  5. * Copyright (c) 1999-2004 The SquirrelMail Project Team
  6. * Licensed under the GNU GPL. For full terms see the file COPYING.
  7. *
  8. * The idea is to inlcude here some functions to make easier
  9. * the right to left implementation by "functionize" some
  10. * html outputs.
  11. *
  12. * @version $Id$
  13. * @package squirrelmail
  14. */
  15. /**
  16. * Generate html tags
  17. *
  18. * @param string $tag Tag to output
  19. * @param string $val Value between tags
  20. * @param string $align Alignment (left, center, etc)
  21. * @param string $bgcolor Back color in hexadecimal
  22. * @param string $xtra Extra options
  23. * @return string HTML ready for output
  24. */
  25. function html_tag( $tag, // Tag to output
  26. $val = '', // Value between tags
  27. $align = '', // Alignment
  28. $bgcolor = '', // Back color
  29. $xtra = '' ) { // Extra options
  30. GLOBAL $languages, $squirrelmail_language;
  31. $align = strtolower( $align );
  32. $bgc = '';
  33. $tag = strtolower( $tag );
  34. if ( isset( $languages[$squirrelmail_language]['DIR']) ) {
  35. $dir = $languages[$squirrelmail_language]['DIR'];
  36. } else {
  37. $dir = 'ltr';
  38. }
  39. if ( $dir == 'ltr' ) {
  40. $rgt = 'right';
  41. $lft = 'left';
  42. } else {
  43. $rgt = 'left';
  44. $lft = 'right';
  45. }
  46. if ( $bgcolor <> '' ) {
  47. $bgc = " bgcolor=\"$bgcolor\"";
  48. }
  49. switch ( $align ) {
  50. case '':
  51. $alg = '';
  52. break;
  53. case 'right':
  54. $alg = " align=\"$rgt\"";
  55. break;
  56. case 'left':
  57. $alg = " align=\"$lft\"";
  58. break;
  59. default:
  60. $alg = " align=\"$align\"";
  61. break;
  62. }
  63. $ret = "<$tag";
  64. if ( $dir <> 'ltr' ) {
  65. $ret .= " dir=\"$dir\"";
  66. }
  67. $ret .= $bgc . $alg;
  68. if ( $xtra <> '' ) {
  69. $ret .= " $xtra";
  70. }
  71. if ( $val <> '' ) {
  72. $ret .= ">$val</$tag>";
  73. } else {
  74. $ret .= '>';
  75. }
  76. return( $ret );
  77. }
  78. /* handy function to set url vars */
  79. /* especially usefull when $url = $PHP_SELF */
  80. function set_url_var($url, $var, $val=0, $link=true) {
  81. $k = '';
  82. $ret = '';
  83. $pat_a = array (
  84. '/.+(\\&'.$var.')=(.*)\\&/AU', /* in the middle */
  85. '/.+\\?('.$var.')=(.*\\&).+/AU', /* at front, more follow */
  86. '/.+(\\?'.$var.')=(.*)$/AU', /* at front and only var */
  87. '/.+(\\&'.$var.')=(.*)$/AU' /* at the end */
  88. );
  89. preg_replace('/&amp;/','&',$url);
  90. switch (true) {
  91. case (preg_match($pat_a[0],$url,$regs)):
  92. $k = $regs[1];
  93. $v = $regs[2];
  94. break;
  95. case (preg_match($pat_a[1],$url,$regs)):
  96. $k = $regs[1];
  97. $v = $regs[2];
  98. break;
  99. case (preg_match($pat_a[2],$url,$regs)):
  100. $k = $regs[1];
  101. $v = $regs[2];
  102. break;
  103. case (preg_match($pat_a[3],$url,$regs)):
  104. $k = $regs[1];
  105. $v = $regs[2];
  106. break;
  107. default:
  108. if ($val) {
  109. if (strpos($url,'?')) {
  110. $url .= "&$var=$val";
  111. } else {
  112. $url .= "?$var=$val";
  113. }
  114. }
  115. break;
  116. }
  117. if ($k) {
  118. if ($val) {
  119. $rpl = "$k=$val";
  120. if ($link) {
  121. $rpl = preg_replace('/&/','&amp;',$rpl);
  122. }
  123. } else {
  124. $rpl = '';
  125. }
  126. $pat = "/$k=$v/";
  127. $url = preg_replace($pat,$rpl,$url);
  128. }
  129. return $url;
  130. }
  131. /* Temporary test function to proces template vars with formatting.
  132. * I use it for viewing the message_header (view_header.php) with
  133. * a sort of template.
  134. */
  135. function echo_template_var($var, $format_ar = array() ) {
  136. $frm_last = count($format_ar) -1;
  137. if (isset($format_ar[0])) echo $format_ar[0];
  138. $i = 1;
  139. switch (true) {
  140. case (is_string($var)):
  141. echo $var;
  142. break;
  143. case (is_array($var)):
  144. $frm_a = array_slice($format_ar,1,$frm_last-1);
  145. foreach ($var as $a_el) {
  146. if (is_array($a_el)) {
  147. echo_template_var($a_el,$frm_a);
  148. } else {
  149. echo $a_el;
  150. if (isset($format_ar[$i])) {
  151. echo $format_ar[$i];
  152. }
  153. $i++;
  154. }
  155. }
  156. break;
  157. default:
  158. break;
  159. }
  160. if (isset($format_ar[$frm_last]) && $frm_last>$i ) {
  161. echo $format_ar[$frm_last];
  162. }
  163. }
  164. ?>