本文整理汇总了PHP中CRM_Core_Form::buildForm方法的典型用法代码示例。如果您正苦于以下问题:PHP CRM_Core_Form::buildForm方法的具体用法?PHP CRM_Core_Form::buildForm怎么用?PHP CRM_Core_Form::buildForm使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CRM_Core_Form
的用法示例。
在下文中一共展示了CRM_Core_Form::buildForm方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: perform
/**
* Processes the request.
*
* @param CRM_Core_Form $page
* CRM_Core_Form the current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*
* @return object|void
*/
public function perform(&$page, $actionName)
{
// save the form values and validation status to the session
$page->isFormBuilt() or $page->buildForm();
$pageName = $page->getAttribute('name');
$data =& $page->controller->container();
$data['values'][$pageName] = $page->exportValues();
return $page->handle('display');
}
示例2: perform
/**
* Processes the request.
*
* @param CRM_Core_Form $page
* The current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*
* @return void
*/
public function perform(&$page, $actionName)
{
// save the form values and validation status to the session
$page->isFormBuilt() or $page->buildForm();
$pageName = $page->getAttribute('name');
$data =& $page->controller->container();
$data['values'][$pageName] = $page->exportValues();
$data['valid'][$pageName] = $page->validate();
// Modal form and page is invalid: don't go further
if ($page->controller->isModal() && !$data['valid'][$pageName]) {
return $page->handle('display');
}
// the page is valid, process it before we jump to the next state
$page->mainProcess();
return $page->handle('jump');
}
示例3: perform
/**
* Processes the request.
* this is basically a self submit, so validate the page
* and if success, call post process
* when done processing pop to user context
*
* @param CRM_Core_Form $page
* The current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*
* @return object|void
*/
public function perform(&$page, $actionName)
{
$page->isFormBuilt() or $page->buildForm();
$pageName = $page->getAttribute('name');
$data =& $page->controller->container();
$data['values'][$pageName] = $page->exportValues();
$data['valid'][$pageName] = $page->validate();
// Modal form and page is invalid: don't go further
if ($page->controller->isModal() && !$data['valid'][$pageName]) {
return $page->handle('display');
}
// the page is valid, process it before we jump to the next state
$page->mainProcess();
// ok so we are done now, pop stack and jump back to where we came from
// we do not reset the context because u can achieve that affect using next
// use Done when u want to pop back to the same context without a reset
$this->popUserContext();
}
示例4: buildForm
public function buildForm()
{
parent::buildForm();
$config = CRM_Chapters_AutomatchConfig::singelton();
$this->addElement('hidden', 'cid', $this->contact_id);
if ($this->id) {
$this->addElement('hidden', 'id', $this->id);
}
if ($this->_action & CRM_Core_Action::DELETE) {
$this->addButtons(array(array('type' => 'next', 'name' => ts('Delete'), 'isDefault' => TRUE), array('type' => 'cancel', 'name' => ts('Cancel'))));
return;
}
$types = CRM_Core_OptionGroup::values('chapter_match_type');
$countries = CRM_Core_OptionGroup::values('chapter_match_country');
$this->add('select', 'type', $config->getMatchTypeField('label'), $types);
$this->add('select', 'country', $config->getCountryField('label'), $countries);
$this->addElement('text', 'zipcode_from', $config->getZipCodeRangeFromField('label'));
$this->addElement('text', 'zipcode_to', $config->getZipCodeRangeToField('label'));
$this->addButtons(array(array('type' => 'next', 'name' => ts('Save'), 'isDefault' => TRUE), array('type' => 'cancel', 'name' => ts('Cancel'))));
}
示例5: perform
/**
* Processes the request.
*
* @param CRM_Core_Form $page
* CRM_Core_Form the current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*
* @return void
*/
public function perform(&$page, $actionName)
{
$page->isFormBuilt() or $page->buildForm();
$pageName = $page->getAttribute('name');
$data =& $page->controller->container();
$data['values'][$pageName] = $page->exportValues();
$data['valid'][$pageName] = $page->validate();
// Modal form and page is invalid: don't go further
if ($page->controller->isModal() && !$data['valid'][$pageName]) {
return $page->handle('display');
}
// the page is valid, process it before we jump to the next state
$page->mainProcess();
// check if destination is set, if so goto destination
$destination = $this->_stateMachine->getDestination();
if ($destination) {
$destination = urldecode($destination);
CRM_Utils_System::redirect($destination);
} else {
return $page->handle('display');
}
}
示例6: perform
/**
* Do a state transition jump.
*
* Currently only supported types are
* Next and Back. The other actions (Cancel, Done, Submit etc) do
* not need the state machine to figure out where to go
*
* @param CRM_Core_Form $page
* The current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
* @param string $type
* The type of transition being requested (Next or Back).
*
* @return object
*/
public function perform(&$page, $actionName, $type = 'Next')
{
// save the form values and validation status to the session
$page->isFormBuilt() or $page->buildForm();
$pageName = $page->getAttribute('name');
$data =& $page->controller->container();
$data['values'][$pageName] = $page->exportValues();
$data['valid'][$pageName] = $page->validate();
// if we are going to the next state
// Modal form and page is invalid: don't go further
if ($type == 'Next' && !$data['valid'][$pageName]) {
return $page->handle('display');
}
$state =& $this->_states[$pageName];
// dont know how or why we landed here so abort and display
// current page
if (empty($state)) {
return $page->handle('display');
}
// the page is valid, process it if we are jumping to the next state
if ($type == 'Next') {
$page->mainProcess();
// we get the state again, since postProcess might have changed it
// this bug took me forever to find :) Lobo
$state =& $this->_states[$pageName];
$state->handleNextState($page);
} else {
$state->handleBackState($page);
}
}
示例7: perform
/**
* Processes the request.
*
* @param CRM_Core_Form $page
* CRM_Core_Form the current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*
* @return object|void
*/
public function perform(&$page, $actionName)
{
$pageName = $page->getAttribute('id');
// If the original action was 'display' and we have values in container then we load them
// BTW, if the page was invalid, we should later call validate() to get the errors
list(, $oldName) = $page->controller->getActionName();
if ('display' == $oldName) {
// If the controller is "modal" we should not allow direct access to a page
// unless all previous pages are valid (see also bug #2323)
if ($page->controller->isModal() && !$page->controller->isValid($page->getAttribute('id'))) {
$target =& $page->controller->getPage($page->controller->findInvalid());
return $target->handle('jump');
}
$data =& $page->controller->container();
if (!empty($data['values'][$pageName])) {
$page->loadValues($data['values'][$pageName]);
$validate = FALSE === $data['valid'][$pageName];
}
}
// set "common" defaults and constants
$page->controller->applyDefaults($pageName);
$page->isFormBuilt() or $page->buildForm();
// if we had errors we should show them again
if (isset($validate) && $validate) {
$page->validate();
}
//will this work generally as TRUE (i.e., return output)
//was default, i.e., FALSE
return $this->renderForm($page);
}
示例8: perform
/**
* Processes the request.
*
* @param CRM_Core_Form $page
* CRM_Core_Form the current form-page.
* @param string $actionName
* Current action name, as one Action object can serve multiple actions.
*/
public function perform(&$page, $actionName)
{
// like in Action_Next
$page->isFormBuilt() or $page->buildForm();
// so this is a brain-seizure moment, so hang tight (real tight!)
// the above buildForm potentially changes the action function with different args
// so basically the rug might have been pulled from us, so we actually just check
// and potentially call the right one
// this allows standalone form uploads to work nicely
$page->controller->_actions['upload']->realPerform($page, $actionName);
}