summaryrefslogtreecommitdiff
path: root/framework/Web
diff options
context:
space:
mode:
authorxue <>2005-12-03 16:19:08 +0000
committerxue <>2005-12-03 16:19:08 +0000
commit3ea63072225a473239227facfabde294bb58ed1d (patch)
tree2716662f13c184f31281bab45871c3ad3c9634b4 /framework/Web
parentbdd139266bbd71b828394a1500551254fc42a819 (diff)
Diffstat (limited to 'framework/Web')
-rw-r--r--framework/Web/UI/THiddenFieldPageStatePersister.php9
-rw-r--r--framework/Web/UI/TPage.php40
2 files changed, 17 insertions, 32 deletions
diff --git a/framework/Web/UI/THiddenFieldPageStatePersister.php b/framework/Web/UI/THiddenFieldPageStatePersister.php
index bd32f686..5525b50a 100644
--- a/framework/Web/UI/THiddenFieldPageStatePersister.php
+++ b/framework/Web/UI/THiddenFieldPageStatePersister.php
@@ -14,6 +14,7 @@ class THiddenFieldPageStatePersister extends TComponent implements IPageStatePer
public function init($application, $config)
{
$this->_application=$application;
+ $application->getService()->setPageStatePersister($this);
}
/**
@@ -36,19 +37,19 @@ class THiddenFieldPageStatePersister extends TComponent implements IPageStatePer
{
$data=Prado::serialize($state);
$hmac=$this->computeHMAC($data,$this->getKey());
- if(function_exists('gzuncompress') && function_exists('gzcompress'))
+ if(extension_loaded('zlib'))
$data=gzcompress($hmac.$data);
else
$data=$hmac.$data;
- $this->_application->getService()->getRequestedPage()->saveStateField($data);
+ $this->_application->getService()->getRequestedPage()->getClientScript()->registerHiddenField(TClientScriptManager::FIELD_PAGE_STATE,base64_encode($data));
}
public function load()
{
- $str=$this->_application->getService()->getRequestedPage()->loadStateField();
+ $str=base64_decode($this->_application->getRequest()->getItems()->itemAt(TClientScriptManager::FIELD_PAGE_STATE));
if($str==='')
return null;
- if(function_exists('gzuncompress') && function_exists('gzcompress'))
+ if(extension_loaded('zlib'))
$data=gzuncompress($str);
else
$data=$str;
diff --git a/framework/Web/UI/TPage.php b/framework/Web/UI/TPage.php
index 9eb50cde..4c04f597 100644
--- a/framework/Web/UI/TPage.php
+++ b/framework/Web/UI/TPage.php
@@ -14,6 +14,10 @@ class TPage extends TTemplateControl
*/
private $_pageService;
/**
+ * @var TForm form instance
+ */
+ private $_form=null;
+ /**
* @var string template file name
*/
private $_templateFile=null;
@@ -37,25 +41,28 @@ class TPage extends TTemplateControl
* @var TClientScriptManager client script manager
*/
private $_clientScript=null;
+ /**
+ * @var TMap data post back by user
+ */
+ private $_postData;
+ /**
+ * @var TMap postback data that is not handled during first invocation of LoadPostData.
+ */
+ private $_restPostData;
private $_maxPageStateFieldLength=10;
private $_enableViewStateMac=true;
private $_performPreRendering=true;
private $_performRendering=true;
- private $_form=null;
private $_formRendered=false;
private $_inFormRender=false;
- private $_pageState='';
private $_requirePostBackScript=false;
private $_postBackScriptRendered=false;
private $_isCrossPagePostBack=false;
private $_previousPagePath='';
private $_preInitWorkComplete=false;
private $_changedPostDataConsumers=array();
- private $_postData;
- private $_restPostData;
- private $_pageStateChanged=false;
private $_controlsRequiringPostBack=array();
private $_registeredControlThatRequireRaiseEvent=null;
private $_registeredControlsThatRequirePostBack=null;
@@ -409,24 +416,6 @@ class TPage extends TTemplateControl
$this->getPageStatePersister()->save($state);
}
- /**
- * Loads page state data from a hidden field.
- * @return string page state data stored in hidden field
- */
- public function loadStateField()
- {
- return base64_decode($this->_postData->itemAt(TClientScriptManager::FIELD_PAGE_STATE));
- }
-
- /**
- * Saves page state data in a hidden field.
- * @param string string representation of the page state data.
- */
- public function saveStateField($state)
- {
- $this->getClientScript()->registerHiddenField(TClientScriptManager::FIELD_PAGE_STATE,base64_encode($state));
- }
-
public function RegisterEnabledControl($control)
{
$this->getEna.EnabledControls.Add(control);
@@ -603,11 +592,6 @@ EOD;
$this->_registeredControlThatRequireRaiseEvent=$control;
}
- public function getApplication()
- {
- return $this->_application;
- }
-
protected function processPostData($postData,$beforeLoad)
{
$eventTarget=$postData->itemAt('__EVENTTARGET');