html.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <?php
  2. /**
  3. * html.php
  4. *
  5. * The idea is to inlcude here some functions to make easier
  6. * the right to left implementation by "functionize" some
  7. * html outputs.
  8. *
  9. * @copyright &copy; 1999-2006 The SquirrelMail Project Team
  10. * @license http://opensource.org/licenses/gpl-license.php GNU Public License
  11. * @version $Id$
  12. * @package squirrelmail
  13. * @since 1.3.0
  14. */
  15. /**
  16. * Generates 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. * @since 1.3.0
  25. */
  26. function html_tag( $tag, // Tag to output
  27. $val = '', // Value between tags
  28. $align = '', // Alignment
  29. $bgcolor = '', // Back color
  30. $xtra = '' ) { // Extra options
  31. GLOBAL $languages, $squirrelmail_language;
  32. $align = strtolower( $align );
  33. $bgc = '';
  34. $tag = strtolower( $tag );
  35. if ( isset( $languages[$squirrelmail_language]['DIR']) ) {
  36. $dir = $languages[$squirrelmail_language]['DIR'];
  37. } else {
  38. $dir = 'ltr';
  39. }
  40. if ( $dir == 'ltr' ) {
  41. $rgt = 'right';
  42. $lft = 'left';
  43. } else {
  44. $rgt = 'left';
  45. $lft = 'right';
  46. }
  47. if ( $bgcolor <> '' ) {
  48. $bgc = " bgcolor=\"$bgcolor\"";
  49. }
  50. switch ( $align ) {
  51. case '':
  52. $alg = '';
  53. break;
  54. case 'right':
  55. $alg = " align=\"$rgt\"";
  56. break;
  57. case 'left':
  58. $alg = " align=\"$lft\"";
  59. break;
  60. default:
  61. $alg = " align=\"$align\"";
  62. break;
  63. }
  64. $ret = "<$tag";
  65. if ( $dir <> 'ltr' ) {
  66. $ret .= " dir=\"$dir\"";
  67. }
  68. $ret .= $bgc . $alg;
  69. if ( $xtra <> '' ) {
  70. $ret .= " $xtra";
  71. }
  72. if ( $val <> '' ) {
  73. $ret .= ">$val</$tag>\n";
  74. } else {
  75. $ret .= '>'. "\n";
  76. }
  77. return( $ret );
  78. }
  79. /**
  80. * handy function to set url vars
  81. *
  82. * especially useful when $url = $PHP_SELF
  83. * @param string $url url that must be modified
  84. * @param string $var variable name
  85. * @param string $val variable value
  86. * @param boolean $link controls sanitizing of ampersand in urls (since 1.3.2)
  87. * @return string $url modified url
  88. * @since 1.3.0
  89. */
  90. function set_url_var($url, $var, $val=0, $link=true) {
  91. $k = '';
  92. $pat_a = array (
  93. '/.+(\\&'.$var.')=(.*)\\&/AU', /* in the middle */
  94. '/.+\\?('.$var.')=(.*\\&).+/AU', /* at front, more follow */
  95. '/.+(\\?'.$var.')=(.*)$/AU', /* at front and only var */
  96. '/.+(\\&'.$var.')=(.*)$/AU' /* at the end */
  97. );
  98. preg_replace('/&amp;/','&',$url);
  99. // FIXME: why switch is used instead of if () or one preg_match()
  100. switch (true) {
  101. case (preg_match($pat_a[0],$url,$regs)):
  102. $k = $regs[1];
  103. $v = $regs[2];
  104. break;
  105. case (preg_match($pat_a[1],$url,$regs)):
  106. $k = $regs[1];
  107. $v = $regs[2];
  108. break;
  109. case (preg_match($pat_a[2],$url,$regs)):
  110. $k = $regs[1];
  111. $v = $regs[2];
  112. break;
  113. case (preg_match($pat_a[3],$url,$regs)):
  114. $k = $regs[1];
  115. $v = $regs[2];
  116. break;
  117. default:
  118. if ($val) {
  119. if (strpos($url,'?')) {
  120. $url .= "&$var=$val";
  121. } else {
  122. $url .= "?$var=$val";
  123. }
  124. }
  125. break;
  126. }
  127. if ($k) {
  128. if ($val) {
  129. $rpl = "$k=$val";
  130. if ($link) {
  131. $rpl = preg_replace('/&/','&amp;',$rpl);
  132. }
  133. } else {
  134. $rpl = '';
  135. }
  136. if( substr($v,-1)=='&' ) {
  137. $rpl .= '&';
  138. }
  139. $pat = "/$k=$v/";
  140. $url = preg_replace($pat,$rpl,$url);
  141. }
  142. return $url;
  143. }