diff options
author | xue <> | 2006-04-11 19:51:01 +0000 |
---|---|---|
committer | xue <> | 2006-04-11 19:51:01 +0000 |
commit | 961777817a3543dbe179711b8ad1021a8128c83d (patch) | |
tree | 76983c7022dcf240ba17b099459f75a8ac0cabf1 /framework | |
parent | ffc189729b2ce96c35dc78a754dfb15b478c5220 (diff) |
Added Raw layout to TDataList.
Diffstat (limited to 'framework')
-rw-r--r-- | framework/Web/UI/WebControls/TDataList.php | 5 | ||||
-rw-r--r-- | framework/Web/UI/WebControls/TRepeatInfo.php | 38 |
2 files changed, 38 insertions, 5 deletions
diff --git a/framework/Web/UI/WebControls/TDataList.php b/framework/Web/UI/WebControls/TDataList.php index f5f4b9fa..695d072a 100644 --- a/framework/Web/UI/WebControls/TDataList.php +++ b/framework/Web/UI/WebControls/TDataList.php @@ -627,7 +627,7 @@ class TDataList extends TBaseDataList implements INamingContainer, IRepeatInfoUs }
/**
- * @param string how the list should be displayed, using table or using line breaks (Table, Flow)
+ * @param string how the list should be displayed, using table or using line breaks (Table, Flow, Raw)
*/
public function setRepeatLayout($value)
{
@@ -825,7 +825,8 @@ class TDataList extends TBaseDataList implements INamingContainer, IRepeatInfoUs public function renderItem($writer,$repeatInfo,$itemType,$index)
{
$item=$this->getItem($itemType,$index);
- if($repeatInfo->getRepeatLayout()==='Table')
+ $layout=$repeatInfo->getRepeatLayout();
+ if($layout==='Table' || $layout==='Raw')
$item->renderContents($writer);
else
$item->renderControl($writer);
diff --git a/framework/Web/UI/WebControls/TRepeatInfo.php b/framework/Web/UI/WebControls/TRepeatInfo.php index 5f4fb825..10c49691 100644 --- a/framework/Web/UI/WebControls/TRepeatInfo.php +++ b/framework/Web/UI/WebControls/TRepeatInfo.php @@ -57,13 +57,16 @@ interface IRepeatInfoUser * TRepeatInfo class.
* TRepeatInfo represents repeat information for controls like {@link TCheckBoxList}.
* The layout of the repeated items is specified via {@link setRepeatLayout RepeatLayout},
- * which can be either 'Table' (default) or 'Flow'.
+ * which can be either 'Table' (default), 'Flow' or 'Raw'.
* A table layout uses HTML table cells to organize the items while
* a flow layout uses line breaks to organize the items.
* The number of columns used to display the items is specified via
* {@link setRepeatColumns RepeatColumns} property, while the {@link setRepeatDirection RepeatDirection}
* governs the order of the items being rendered.
*
+ * Note, the Raw layout does not contain any formatting tags and thus ignores
+ * the column and repeat direction settings.
+ *
* @author Qiang Xue <qiang.xue@gmail.com>
* @version $Revision: $ $Date: $
* @package System.Web.UI.WebControls
@@ -169,11 +172,12 @@ class TRepeatInfo extends TComponent }
/**
- * @param string how the repeated items should be displayed, using table or using line breaks. Defaults to 'Table'.
+ * @param string how the repeated items should be displayed, using table or using line breaks.
+ * Valid values include 'Table', 'Flow' and 'Raw'.
*/
public function setRepeatLayout($value)
{
- $this->_repeatLayout=TPropertyValue::ensureEnum($value,array('Table','Flow'));
+ $this->_repeatLayout=TPropertyValue::ensureEnum($value,array('Table','Flow','Raw'));
}
/**
@@ -192,6 +196,11 @@ class TRepeatInfo extends TComponent $control->setCaptionAlign($this->_captionAlign);
}
}
+ else if($this->_repeatLayout==='Raw')
+ {
+ $this->renderRawContents($writer,$user);
+ return;
+ }
else
$control=new TWebControl;
$control->setID($user->getClientID());
@@ -210,6 +219,29 @@ class TRepeatInfo extends TComponent }
/**
+ * Renders contents in raw format.
+ * @param THtmlWriter writer for the rendering purpose
+ * @param IRepeatInfoUser repeat information user
+ */
+ protected function renderRawContents($writer,$user)
+ {
+ if($user->getHasHeader())
+ $user->renderItem($writer,$this,'Header',-1);
+
+ // render items
+ $hasSeparators=$user->getHasSeparators();
+ $itemCount=$user->getItemCount();
+ for($i=0;$i<$itemCount;++$i)
+ {
+ $user->renderItem($writer,$this,'Item',$i);
+ if($hasSeparators && $i!=$itemCount-1)
+ $user->renderItem($writer,$this,'Separator',$i);
+ }
+ if($user->getHasFooter())
+ $user->renderItem($writer,$this,'Footer',-1);
+ }
+
+ /**
* Renders contents in horizontal repeat direction.
* @param THtmlWriter writer for the rendering purpose
* @param IRepeatInfoUser repeat information user
|