A QCodo powered CMS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

138 lines
4.1 KiB

<?php
if(!defined('QUINTACMS') ) die("No quinta.");
if (!defined("ACCOUNTSETTINGSMODULE.CLASS.PHP")){
define("ACCOUNTSETTINGSMODULE.CLASS.PHP",1);
/**
* Class AccountSettingsModule - provides modifiable display of Account data
* This module contains two panels, one for changing the password and one
* for editing personal information.
*
*@author Erik Winn <sidewalksoftware@gmail.com>
*
*@version 0.3
*
*@package Quinta
* @subpackage Modules
*/
class AccountSettingsModule extends QPanel{
/**
* @var ContentBlockController objControlBlock - usually the AccountManagerModule
*/
protected $objControlBlock;
/**
* @var Account objAccount - local reference or instance of the account
*/
protected $objAccount;
/**
* @var AccountPasswordEditPanel pnlPasswordEdit - panel for changing password and username
*/
public $pnlPasswordEdit;
/**
* @var AccountInfoEditPanel pnlInfoEdit - panel for changing general account information
*/
public $pnlInfoEdit;
/**
* @var QLabel lblMessage - let the user know they have saved ..
*/
public $lblMessage;
/**
* Module constructor
*
*@param QPanel objControlBlock - parent controller object, usually AccountManagerModule.
*@param array aryParameters - extra parameters, if present should be "Password" to indicate password edit
*/
public function __construct( QPanel $objControlBlock, $aryParameters=null){
//Parent should always be a ContentBlockController
$this->objControlBlock =& $objControlBlock;
try {
parent::__construct($this->objControlBlock);
} catch (QCallerException $objExc) {
$objExc->IncrementOffset();
throw $objExc;
}
// $this->strTemplate = __QUINTA_CORE_VIEWS__ . '/AccountSettingsModule.tpl.php';
$this->AutoRenderChildren = true;
$this->lblMessage = new QLabel($this);
$this->lblMessage->HtmlEntities = false;
$this->objAccount =& IndexPage::$objAccount;
if( null != $aryParameters && 'Password' == $aryParameters[0]){
$this->pnlPasswordEdit = new AccountPasswordEditPanel($this, $this, 'ClosePasswordPanel');
$this->pnlPasswordEdit->Visible = true;
}else{
$this->pnlInfoEdit = new AccountInfoEditPanel($this, 'pnlInfoEdit');
$this->pnlInfoEdit->Visible = true;
}
}
/**
* Unused
*/
public function Validate(){
$blnToReturn = true;
// validate input here
return $blnToReturn;
}
/**
* This function closes the password edit panel (by removing all child controls) and shows
* the general info editting panel again. It is called from an action in the password edit panel
*/
public function ClosePasswordPanel($blnUpdatesMade){
$this->RemoveChildControls(true);
$this->pnlInfoEdit = new AccountInfoEditPanel($this, 'pnlInfoEdit');
$this->pnlInfoEdit->Visible = true;
$this->lblMessage->Text = Quinta::Translate('Password Saved') .'!';
}
/**
* This function closes the general information edit panel (by removing all child controls) and shows
* the password edit panel when the user selects the "Change password" button
*/
public function btnChangePassword_Click($strFormId, $strControlId, $strParameter){
$this->RemoveChildControls(true);
$this->pnlPasswordEdit = new AccountPasswordEditPanel($this, $this, 'ClosePasswordPanel');
$this->pnlPasswordEdit->Visible = true;
}
///gettors
public function __get($strName){
switch ($strName){
case 'Account':
return $this->objAccount ;
default:
try {
return parent::__get($strName);
} catch (QCallerException $objExc) {
$objExc->IncrementOffset();
throw $objExc;
}
}
}
public function __set($strName, $mixValue){
switch ($strName){
case 'Account':
try {
return ($this->objAccount = QType::Cast($mixValue, 'Account' ));
} catch (QInvalidCastException $objExc) {
$objExc->IncrementOffset();
throw $objExc;
}
default:
try {
return (parent::__set($strName, $mixValue));
} catch (QCallerException $objExc) {
$objExc->IncrementOffset();
throw $objExc;
}
}
}
}//end class
}//end define
?>