3 +--------------------------------------------------------------------+
4 | Copyright CiviCRM LLC. All rights reserved. |
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 +--------------------------------------------------------------------+
14 * @copyright CiviCRM LLC https://civicrm.org/licensing
18 * This is a shared parent class for form task actions.
20 abstract class CRM_Core_Form_Task
extends CRM_Core_Form
{
23 * The task being performed
30 * The additional clause that we restrict the search with
34 protected $_componentClause = NULL;
37 * The array that holds all the component ids
41 protected $_componentIds;
49 * The array that holds all the case ids
56 * The array that holds all the contact ids
63 * Must be set to entity table name (eg. civicrm_participant) by child class
67 public static $tableName = NULL;
70 * Must be set to entity shortname (eg. event)
74 public static $entityShortname = NULL;
77 * Build all the data structures needed to build the form.
79 * @throws \CRM_Core_Exception
81 public function preProcess() {
82 self
::preProcessCommon($this);
86 * Common pre-processing function.
88 * @param CRM_Core_Form_Task $form
90 * @throws \CRM_Core_Exception
92 public static function preProcessCommon(&$form) {
93 $form->_entityIds
= [];
95 $searchFormValues = $form->getSearchFormValues();
97 $form->_task
= $searchFormValues['task'];
100 if ($searchFormValues['radio_ts'] == 'ts_sel') {
101 foreach ($searchFormValues as $name => $value) {
102 if (substr($name, 0, CRM_Core_Form
::CB_PREFIX_LEN
) == CRM_Core_Form
::CB_PREFIX
) {
103 $entityIds[] = substr($name, CRM_Core_Form
::CB_PREFIX_LEN
);
108 $queryParams = $form->get('queryParams');
110 if ($form->get(CRM_Utils_Sort
::SORT_ORDER
)) {
111 $sortOrder = $form->get(CRM_Utils_Sort
::SORT_ORDER
);
114 $query = new CRM_Contact_BAO_Query($queryParams, NULL, NULL, FALSE, FALSE, $form->getQueryMode());
115 $query->_distinctComponentClause
= " ( " . $form::$tableName . ".id )";
116 $query->_groupByComponentClause
= " GROUP BY " . $form::$tableName . ".id ";
117 $result = $query->searchQuery(0, 0, $sortOrder);
118 $selector = $form::$entityShortname . '_id';
119 while ($result->fetch()) {
120 $entityIds[] = $result->$selector;
124 if (!empty($entityIds)) {
125 $form->_componentClause
= ' ' . $form::$tableName . '.id IN ( ' . implode(',', $entityIds) . ' ) ';
126 $form->assign('totalSelected' . ucfirst($form::$entityShortname) . 's', count($entityIds));
129 $form->_entityIds
= $form->_componentIds
= $entityIds;
131 // Some functions (eg. PDF letter tokens) rely on Ids being in specific fields rather than the generic $form->_entityIds
132 // So we set that specific field here (eg. for cases $form->_caseIds = $form->_entityIds).
133 // FIXME: This is really to handle legacy code that should probably be updated to use $form->_entityIds
134 $entitySpecificIdsName = '_' . $form::$entityShortname . 'Ids';
135 $form->$entitySpecificIdsName = $form->_entityIds
;
137 //set the context for redirection for any task actions
138 $qfKey = CRM_Utils_Request
::retrieve('qfKey', 'String', $form);
139 $urlParams = 'force=1';
140 if (CRM_Utils_Rule
::qfKey($qfKey)) {
141 $urlParams .= "&qfKey=$qfKey";
144 $session = CRM_Core_Session
::singleton();
145 $searchFormName = strtolower($form->get('searchFormName'));
146 if ($searchFormName == 'search') {
147 $session->replaceUserContext(CRM_Utils_System
::url('civicrm/' . $form::$entityShortname . '/search', $urlParams));
150 $session->replaceUserContext(CRM_Utils_System
::url("civicrm/contact/search/$searchFormName",
157 * Given the entity id, compute the contact id since its used for things like send email
158 * For example, for cases we need to override this function as the table name is civicrm_case_contact
160 public function setContactIDs() {
161 $this->_contactIds
= CRM_Core_DAO
::getContactIDsFromComponent($this->_entityIds
,
167 * Add buttons to the form.
169 * @param string $title
170 * Title of the main button.
171 * @param string $nextType
172 * Button type for the form after processing.
173 * @param string $backType
174 * @param bool $submitOnce
176 public function addDefaultButtons($title, $nextType = 'next', $backType = 'back', $submitOnce = FALSE) {
185 'name' => ts('Cancel'),
191 * Get the query mode (eg. CRM_Core_BAO_Query::MODE_CASE)
192 * Should be overridden by child classes in most cases
196 public function getQueryMode() {
197 return $this->queryMode ?
: CRM_Contact_BAO_Query
::MODE_CONTACTS
;
201 * Given the component id, compute the contact id
202 * since it's used for things like send email.
204 * @todo At the moment this duplicates a similar function in CRM_Core_DAO
205 * because right now only the case component is using this. Since the
206 * default $orderBy is '' which is what the original does, others should be
207 * easily convertable as NFC.
208 * @todo The passed in variables should be class member variables. Shouldn't
209 * need to have passed in vars.
211 * @param $componentIDs
212 * @param string $tableName
213 * @param string $idField
217 public function getContactIDsFromComponent($componentIDs, $tableName, $idField = 'id') {
220 if (empty($componentIDs)) {
224 $orderBy = $this->orderBy();
226 $IDs = implode(',', $componentIDs);
230 WHERE $idField IN ( $IDs ) $orderBy
233 $dao = CRM_Core_DAO
::executeQuery($query);
234 while ($dao->fetch()) {
235 $contactIDs[] = $dao->contact_id
;
241 * Default ordering for getContactIDsFromComponent. Subclasses can override.
244 * SQL fragment. Either return '' or a valid order clause including the
245 * words "ORDER BY", e.g. "ORDER BY `{$this->idField}`"
247 public function orderBy() {
252 * Get the submitted values for the form.
256 public function getSearchFormValues() {
257 if ($this->_action
=== CRM_Core_Action
::ADVANCED
) {
258 return $this->controller
->exportValues('Advanced');
260 if ($this->_action
=== CRM_Core_Action
::PROFILE
) {
261 return $this->controller
->exportValues('Builder');
263 if ($this->_action
== CRM_Core_Action
::COPY
) {
264 return $this->controller
->exportValues('Custom');
266 if ($this->get('entity') !== 'Contact') {
267 return $this->controller
->exportValues('Search');
269 return $this->controller
->exportValues('Basic');