3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2014
37 * This class generates form components for adding a petition
40 class CRM_Campaign_Form_Petition
extends CRM_Core_Form
{
43 * Making this public so we can reference it in the formRule
48 public function preProcess() {
49 if (!CRM_Campaign_BAO_Campaign
::accessCampaign()) {
50 CRM_Utils_System
::permissionDenied();
53 $this->_context
= CRM_Utils_Request
::retrieve('context', 'String', $this);
55 $this->assign('context', $this->_context
);
57 $this->_action
= CRM_Utils_Request
::retrieve('action', 'String', $this);
59 if ($this->_action
& (CRM_Core_Action
::UPDATE | CRM_Core_Action
::DELETE
)) {
60 $this->_surveyId
= CRM_Utils_Request
::retrieve('id', 'Positive', $this, TRUE);
62 if ($this->_action
& CRM_Core_Action
::UPDATE
) {
63 CRM_Utils_System
::setTitle(ts('Edit Survey'));
66 CRM_Utils_System
::setTitle(ts('Delete Survey'));
70 $this->_cdType
= CRM_Utils_Array
::value('type', $_GET);
71 $this->assign('cdType', FALSE);
73 $this->assign('cdType', TRUE);
74 return CRM_Custom_Form_CustomData
::preProcess($this);
77 // when custom data is included in this page
78 if (!empty($_POST['hidden_custom'])) {
79 CRM_Custom_Form_CustomData
::preProcess($this);
80 CRM_Custom_Form_CustomData
::buildQuickForm($this);
83 $session = CRM_Core_Session
::singleton();
84 $url = CRM_Utils_System
::url('civicrm/campaign', 'reset=1&subPage=survey');
85 $session->pushUserContext($url);
87 $this->_values
= $this->get('values');
89 if (!is_array($this->_values
)) {
90 $this->_values
= array();
91 if ($this->_surveyId
) {
92 $params = array('id' => $this->_surveyId
);
93 CRM_Campaign_BAO_Survey
::retrieve($params, $this->_values
);
95 $this->set('values', $this->_values
);
98 $this->assign('action', $this->_action
);
99 $this->assign('surveyId', $this->_surveyId
);
101 $this->assign('entityID', $this->_surveyId
);
103 if ($this->_action
& (CRM_Core_Action
::UPDATE | CRM_Core_Action
::DELETE
)) {
104 $this->_surveyId
= CRM_Utils_Request
::retrieve('id', 'Positive', $this, TRUE);
106 if ($this->_action
& CRM_Core_Action
::UPDATE
) {
107 CRM_Utils_System
::setTitle(ts('Edit Petition'));
110 CRM_Utils_System
::setTitle(ts('Delete Petition'));
114 $session = CRM_Core_Session
::singleton();
115 $url = CRM_Utils_System
::url('civicrm/campaign', 'reset=1&subPage=petition');
116 $session->pushUserContext($url);
118 CRM_Utils_System
::appendBreadCrumb(array(array('title' => ts('Petition Dashboard'), 'url' => $url)));
122 * Set default values for the form. Note that in edit/view mode
123 * the default values are retrieved from the database
128 * array of default values
130 public function setDefaultValues() {
131 $defaults = $this->_values
;
133 $ufContactJoinParams = array(
134 'entity_table' => 'civicrm_survey',
135 'entity_id' => $this->_surveyId
,
139 if ($ufContactGroupId = CRM_Core_BAO_UFJoin
::findUFGroupId($ufContactJoinParams)) {
140 $defaults['contact_profile_id'] = $ufContactGroupId;
142 $ufActivityJoinParams = array(
143 'entity_table' => 'civicrm_survey',
144 'entity_id' => $this->_surveyId
,
148 if ($ufActivityGroupId = CRM_Core_BAO_UFJoin
::findUFGroupId($ufActivityJoinParams)) {
149 $defaults['profile_id'] = $ufActivityGroupId;
152 if (!isset($defaults['is_active'])) {
153 $defaults['is_active'] = 1;
156 $defaultSurveys = CRM_Campaign_BAO_Survey
::getSurveys(TRUE, TRUE);
157 if (!isset($defaults['is_default']) && empty($defaultSurveys)) {
158 $defaults['is_default'] = 1;
165 public function buildQuickForm() {
167 if ($this->_action
& CRM_Core_Action
::DELETE
) {
172 'name' => ts('Delete'),
177 'name' => ts('Cancel'),
184 $this->add('text', 'title', ts('Petition Title'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'title'), TRUE);
186 $attributes = CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey');
188 $petitionTypeID = CRM_Core_OptionGroup
::getValue('activity_type', 'petition', 'name');
189 $this->addElement('hidden', 'activity_type_id', $petitionTypeID);
191 // script / instructions / description of petition purpose
192 $this->addWysiwyg('instructions', ts('Introduction'), $attributes['instructions']);
195 $campaigns = CRM_Campaign_BAO_Campaign
::getCampaigns(CRM_Utils_Array
::value('campaign_id', $this->_values
));
196 $this->add('select', 'campaign_id', ts('Campaign'), array('' => ts('- select -')) +
$campaigns);
198 $customContactProfiles = CRM_Core_BAO_UFGroup
::getProfiles(array('Individual'));
200 $this->add('select', 'contact_profile_id', ts('Contact Profile'),
202 '' => ts('- select -')
203 ) +
$customContactProfiles, TRUE
206 $customProfiles = CRM_Core_BAO_UFGroup
::getProfiles(array('Activity'));
208 $this->add('select', 'profile_id', ts('Activity Profile'),
210 '' => ts('- select -'),
214 // thank you title and text (html allowed in text)
215 $this->add('text', 'thankyou_title', ts('Thank-you Page Title'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'thankyou_title'));
216 $this->addWysiwyg('thankyou_text', ts('Thank-you Message'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'thankyou_text'));
218 // bypass email confirmation?
219 $this->add('checkbox', 'bypass_confirm', ts('Bypass email confirmation'));
221 //is share through social media
222 $this->addElement('checkbox', 'is_share', ts('Allow sharing through social media?'));
225 $this->add('checkbox', 'is_active', ts('Is Active?'));
228 $this->add('checkbox', 'is_default', ts('Is Default?'));
235 'name' => ts('Save'),
240 'name' => ts('Save and New'),
245 'name' => ts('Cancel'),
250 // add a form rule to check default value
251 $this->addFormRule(array('CRM_Campaign_Form_Petition', 'formRule'), $this);
255 * Global validation rules for the form
261 public static function formRule($fields, $files, $form) {
263 // Petitions should be unique by: title, campaign ID (if assigned) and activity type ID
264 // NOTE: This class is called for both Petition create / update AND for Survey Results tab, but this rule is only for Petition.
265 $where = array('activity_type_id = %1', 'title = %2');
267 1 => array($fields['activity_type_id'], 'Integer'),
268 2 => array($fields['title'], 'String'),
270 $uniqueRuleErrorMessage = ts('This title is already associated with the selected activity type. Please specify a unique title.');
272 if (empty($fields['campaign_id'])) {
273 $where[] = 'campaign_id IS NULL';
276 $where[] = 'campaign_id = %3';
277 $params[3] = array($fields['campaign_id'], 'Integer');
278 $uniqueRuleErrorMessage = ts('This title is already associated with the selected campaign and activity type. Please specify a unique title.');
281 // Exclude current Petition row if UPDATE.
282 if ($form->_surveyId
) {
283 $where[] = 'id != %4';
284 $params[4] = array($form->_surveyId
, 'Integer');
287 $whereClause = implode(' AND ', $where);
290 SELECT COUNT(*) AS row_count
295 $result = CRM_Core_DAO
::singleValueQuery($query, $params);
297 $errors['title'] = $uniqueRuleErrorMessage;
299 return empty($errors) ?
TRUE : $errors;
303 public function postProcess() {
304 // store the submitted values in an array
305 $params = $this->controller
->exportValues($this->_name
);
307 $session = CRM_Core_Session
::singleton();
309 $params['last_modified_id'] = $session->get('userID');
310 $params['last_modified_date'] = date('YmdHis');
311 $params['is_share'] = CRM_Utils_Array
::value('is_share', $params, FALSE);
313 if ($this->_surveyId
) {
315 if ($this->_action
& CRM_Core_Action
::DELETE
) {
316 CRM_Campaign_BAO_Survey
::del($this->_surveyId
);
317 CRM_Core_Session
::setStatus(ts(' Petition has been deleted.'), ts('Record Deleted'), 'success');
318 $session->replaceUserContext(CRM_Utils_System
::url('civicrm/campaign', 'reset=1&subPage=petition'));
322 $params['id'] = $this->_surveyId
;
325 $params['created_id'] = $session->get('userID');
326 $params['created_date'] = date('YmdHis');
329 $params['bypass_confirm'] = CRM_Utils_Array
::value('bypass_confirm', $params, 0);
330 $params['is_active'] = CRM_Utils_Array
::value('is_active', $params, 0);
331 $params['is_default'] = CRM_Utils_Array
::value('is_default', $params, 0);
333 $surveyId = CRM_Campaign_BAO_Survey
::create($params);
335 // also update the ProfileModule tables
336 $ufJoinParams = array(
338 'module' => 'CiviCampaign',
339 'entity_table' => 'civicrm_survey',
340 'entity_id' => $surveyId->id
,
343 // first delete all past entries
344 if ($this->_surveyId
) {
345 CRM_Core_BAO_UFJoin
::deleteAll($ufJoinParams);
347 if (!empty($params['profile_id'])) {
348 $ufJoinParams['weight'] = 1;
349 $ufJoinParams['uf_group_id'] = $params['profile_id'];
350 CRM_Core_BAO_UFJoin
::create($ufJoinParams);
353 if (!empty($params['contact_profile_id'])) {
354 $ufJoinParams['weight'] = 2;
355 $ufJoinParams['uf_group_id'] = $params['contact_profile_id'];
356 CRM_Core_BAO_UFJoin
::create($ufJoinParams);
359 if (!is_a($surveyId, 'CRM_Core_Error')) {
360 CRM_Core_Session
::setStatus(ts('Petition has been saved.'), ts('Saved'), 'success');
363 $buttonName = $this->controller
->getButtonName();
364 if ($buttonName == $this->getButtonName('next', 'new')) {
365 CRM_Core_Session
::setStatus(ts(' You can add another Petition.'), '', 'info');
366 $session->replaceUserContext(CRM_Utils_System
::url('civicrm/petition/add', 'reset=1&action=add'));
369 $session->replaceUserContext(CRM_Utils_System
::url('civicrm/campaign', 'reset=1&subPage=petition'));