| | |
| | | | program/include/html.php | |
| | | | | |
| | | | This file is part of the RoundCube Webmail client | |
| | | | Copyright (C) 2005-2008, RoundCube Dev, - Switzerland | |
| | | | Copyright (C) 2005-2010, RoundCube Dev, - Switzerland | |
| | | | Licensed under the GNU GPL | |
| | | | | |
| | | | PURPOSE: | |
| | |
| | | | Author: Thomas Bruederli <roundcube@gmail.com> | |
| | | +-----------------------------------------------------------------------+ |
| | | |
| | | $Id: $ |
| | | $Id$ |
| | | |
| | | */ |
| | | |
| | |
| | | { |
| | | protected $tagname; |
| | | protected $attrib = array(); |
| | | protected $allowed; |
| | | protected $allowed = array(); |
| | | protected $content; |
| | | |
| | | protected static $common_attrib = array('id','class','style','title','align'); |
| | | public static $containers = array('div','span','p','h1','h2','h3','form','textarea'); |
| | | public static $lc_tags = true; |
| | | public static $common_attrib = array('id','class','style','title','align'); |
| | | public static $containers = array('iframe','div','span','p','h1','h2','h3','form','textarea','table','thead','tbody','tr','th','td','style','script'); |
| | | |
| | | /** |
| | | * Constructor |
| | |
| | | */ |
| | | public function show() |
| | | { |
| | | return self::tag($this->tagname, $this->attrib, $this->content, $this->allowed); |
| | | return self::tag($this->tagname, $this->attrib, $this->content, array_merge(self::$common_attrib, $this->allowed)); |
| | | } |
| | | |
| | | /****** STATIC METHODS *******/ |
| | |
| | | if (is_string($attr)) { |
| | | $attr = array('class' => $attr); |
| | | } |
| | | return self::tag('div', $attr, $cont, self::$common_attrib); |
| | | return self::tag('div', $attr, $cont, array_merge(self::$common_attrib, array('onclick'))); |
| | | } |
| | | |
| | | /** |
| | |
| | | if (is_string($attr)) { |
| | | $attr = array('src' => $attr); |
| | | } |
| | | return self::tag('img', $attr + array('alt' => ''), null, array_merge(self::$common_attrib, array('src','alt','width','height','border','usemap'))); |
| | | return self::tag('img', $attr + array('alt' => ''), null, array_merge(self::$common_attrib, |
| | | array('src','alt','width','height','border','usemap'))); |
| | | } |
| | | |
| | | /** |
| | |
| | | if (is_string($attr)) { |
| | | $attr = array('href' => $attr); |
| | | } |
| | | return self::tag('a', $attr, $cont, array_merge(self::$common_attrib, array('href','target','name','onclick','onmouseover','onmouseout'))); |
| | | return self::tag('a', $attr, $cont, array_merge(self::$common_attrib, |
| | | array('href','target','name','onclick','onmouseover','onmouseout','onmousedown','onmouseup'))); |
| | | } |
| | | |
| | | /** |
| | |
| | | $attr = array('for' => $attr); |
| | | } |
| | | return self::tag('label', $attr, $cont, array_merge(self::$common_attrib, array('for'))); |
| | | } |
| | | |
| | | /** |
| | | * Derrived method to create <iframe></iframe> |
| | | * |
| | | * @param mixed Hash array with tag attributes or string with frame source (src) |
| | | * @return string HTML code |
| | | * @see html::tag() |
| | | */ |
| | | public static function iframe($attr = null, $cont = null) |
| | | { |
| | | if (is_string($attr)) { |
| | | $attr = array('src' => $attr); |
| | | } |
| | | return self::tag('iframe', $attr, $cont, array_merge(self::$common_attrib, |
| | | array('src','name','width','height','border','frameborder'))); |
| | | } |
| | | |
| | | /** |
| | |
| | | { |
| | | protected $tagname = 'input'; |
| | | protected $type = 'text'; |
| | | protected $allowed = array('type','name','value','size','tabindex', |
| | | 'autocomplete','checked','onchange','onclick','disabled','readonly', |
| | | 'spellcheck','results','maxlength','src'); |
| | | |
| | | public function __construct($attrib = array()) |
| | | { |
| | |
| | | class html_textarea extends html |
| | | { |
| | | protected $tagname = 'textarea'; |
| | | protected $allowed_attrib = array('name','rows','cols','wrap','tabindex'); |
| | | protected $allowed = array('name','rows','cols','wrap','tabindex', |
| | | 'onchange','disabled','readonly','spellcheck'); |
| | | |
| | | /** |
| | | * Get HTML code for this object |
| | |
| | | unset($this->attrib['value']); |
| | | } |
| | | |
| | | if (!empty($value) && !isset($this->attrib['mce_editable'])) { |
| | | if (!empty($value) && !preg_match('/mce_editor/', $this->attrib['class'])) { |
| | | $value = Q($value, 'strict', false); |
| | | } |
| | | return self::tag($this->tagname, $this->attrib, $value, array_merge(self::$common_attrib, $this->allowed_attrib)); |
| | | |
| | | return self::tag($this->tagname, $this->attrib, $value, |
| | | array_merge(self::$common_attrib, $this->allowed)); |
| | | } |
| | | } |
| | | |
| | |
| | | { |
| | | protected $tagname = 'select'; |
| | | protected $options = array(); |
| | | protected $allowed = array('name','size','tabindex','autocomplete', |
| | | 'multiple','onchange','disabled'); |
| | | |
| | | /** |
| | | * Add a new option to this drop-down |
| | |
| | | $attr = array( |
| | | 'value' => $option['value'], |
| | | 'selected' => (in_array($option['value'], $select, true) || |
| | | in_array($option['text'], $select, true)) ? 1 : null); |
| | | in_array($option['text'], $select, true)) ? 1 : null); |
| | | |
| | | $this->content .= self::tag('option', $attr, Q($option['text'])); |
| | | } |
| | |
| | | class html_table extends html |
| | | { |
| | | protected $tagname = 'table'; |
| | | protected $allowed = array('id','class','style','width','summary','cellpadding','cellspacing','border'); |
| | | protected $allowed = array('id','class','style','width','summary', |
| | | 'cellpadding','cellspacing','border'); |
| | | |
| | | private $header = array(); |
| | | private $rows = array(); |
| | | private $rowindex = 0; |
| | |
| | | * @param array Cell attributes |
| | | * @param string Cell content |
| | | */ |
| | | private function add_header($attr, $cont) |
| | | public function add_header($attr, $cont) |
| | | { |
| | | if (is_string($attr)) |
| | | $attr = array('class' => $attr); |
| | | $attr = array('class' => $attr); |
| | | |
| | | $cell = new stdClass; |
| | | $cell->attrib = $attr; |
| | |
| | | $this->header[] = $cell; |
| | | } |
| | | |
| | | /** |
| | | * Remove a column from a table |
| | | * Useful for plugins making alterations |
| | | * |
| | | * @param string $class |
| | | */ |
| | | public function remove_column($class) |
| | | { |
| | | // Remove the header |
| | | foreach($this->header as $index=>$header){ |
| | | if($header->attrib['class'] == $class){ |
| | | unset($this->header[$index]); |
| | | break; |
| | | } |
| | | } |
| | | |
| | | // Remove cells from rows |
| | | foreach($this->rows as $i=>$row){ |
| | | foreach($row->cells as $j=>$cell){ |
| | | if($cell->attrib['class'] == $class){ |
| | | unset($this->rows[$i]->cells[$j]); |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | |
| | | /** |
| | | * Jump to next row |
| | | * |
| | | * @param array Row attributes |
| | | */ |
| | | private function add_row($attr = array()) |
| | | public function add_row($attr = array()) |
| | | { |
| | | $this->rowindex++; |
| | | $this->colindex = 0; |
| | |
| | | $this->rows[$this->rowindex]->cells = array(); |
| | | } |
| | | |
| | | /** |
| | | * Set current row attrib |
| | | * |
| | | * @param array Row attributes |
| | | */ |
| | | public function set_row_attribs($attr = array()) |
| | | { |
| | | if (is_string($attr)) |
| | | $attr = array('class' => $attr); |
| | | |
| | | $this->rows[$this->rowindex]->attrib = $attr; |
| | | } |
| | | |
| | | /** |
| | | * Build HTML output of the table data |
| | |
| | | * @param array Table attributes |
| | | * @return string The final table HTML code |
| | | */ |
| | | public function show($attr = array()) |
| | | public function show($attrib = null) |
| | | { |
| | | $this->attrib = array_merge($this->attrib, $attr); |
| | | if (is_array($attrib)) |
| | | $this->attrib = array_merge($this->attrib, $attrib); |
| | | |
| | | $thead = $tbody = ""; |
| | | |
| | | // include <thead> |
| | | if (!empty($this->header)) { |
| | | $rowcontent = ''; |
| | | foreach ($this->header as $c => $col) { |
| | | $rowcontent .= self::tag('th', $col->attrib, $col->content); |
| | | $rowcontent .= self::tag('td', $col->attrib, $col->content); |
| | | } |
| | | $thead = self::tag('thead', null, self::tag('tr', null, $rowcontent)); |
| | | } |
| | |
| | | } |
| | | |
| | | if ($r < $this->rowindex || count($row->cells)) { |
| | | $tbody .= self::tag('tr', $rows->attrib, $rowcontent); |
| | | $tbody .= self::tag('tr', $row->attrib, $rowcontent); |
| | | } |
| | | } |
| | | |
| | |
| | | unset($this->attrib['cols'], $this->attrib['rowsonly']); |
| | | return parent::show(); |
| | | } |
| | | |
| | | /** |
| | | * Count number of rows |
| | | * |
| | | * @return The number of rows |
| | | */ |
| | | public function size() |
| | | { |
| | | return count($this->rows); |
| | | } |
| | | } |
| | | |
| | | ?> |
| | | ?> |