Merge pull request #16762 from eileenmcnaughton/mem_allan
[civicrm-core.git] / CRM / Member / StateMachine / Search.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | Copyright CiviCRM LLC. All rights reserved. |
5 | |
6 | This work is published under the GNU AGPLv3 license with some |
7 | permitted exceptions and without any warranty. For full license |
8 | and copyright information, see https://civicrm.org/licensing |
9 +--------------------------------------------------------------------+
10 */
11
12 /**
13 *
14 * @package CRM
15 * @copyright CiviCRM LLC https://civicrm.org/licensing
16 * $Id$
17 *
18 */
19 class CRM_Member_StateMachine_Search extends CRM_Core_StateMachine {
20
21 /**
22 * The task that the wizard is currently processing.
23 *
24 * @var string
25 */
26 protected $_task;
27
28 /**
29 * Class constructor.
30 *
31 * @param object $controller
32 * @param \const|int $action
33 */
34 public function __construct($controller, $action = CRM_Core_Action::NONE) {
35 parent::__construct($controller, $action);
36
37 $this->_pages = [];
38
39 $this->_pages['CRM_Member_Form_Search'] = NULL;
40 list($task, $result) = $this->taskName($controller, 'Search');
41 $this->_task = $task;
42
43 if (is_array($task)) {
44 foreach ($task as $t) {
45 $this->_pages[$t] = NULL;
46 }
47 }
48 else {
49 $this->_pages[$task] = NULL;
50 }
51 if ($result) {
52 $this->_pages['CRM_Member_Form_Task_Result'] = NULL;
53 }
54 $this->addSequentialPages($this->_pages, $action);
55 }
56
57 /**
58 * Determine the form name based on the action. This allows us
59 * to avoid using conditional state machine, much more efficient
60 * and simpler
61 *
62 * @param CRM_Core_Controller $controller
63 * The controller object.
64 *
65 * @param string $formName
66 *
67 * @return array
68 * the name of the form that will handle the task
69 */
70 public function taskName($controller, $formName = 'Search') {
71 // total hack, check POST vars and then session to determine stuff
72 $value = $_POST['task'] ?? NULL;
73 if (!isset($value)) {
74 $value = $this->_controller->get('task');
75 }
76 $this->_controller->set('task', $value);
77 return CRM_Member_Task::getTask($value);
78 }
79
80 /**
81 * Return the form name of the task.
82 *
83 * @return string
84 */
85 public function getTaskFormName() {
86 return CRM_Utils_String::getClassName($this->_task);
87 }
88
89 /**
90 * Since this is a state machine for search and we want to come back to the same state
91 * we dont want to issue a reset of the state session when we are done processing a task
92 */
93 public function shouldReset() {
94 return FALSE;
95 }
96
97 }