3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2015 |
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-2015
37 * This class generates form components for processing a survey
40 class CRM_Campaign_Form_Survey_Main
extends CRM_Campaign_Form_Survey
{
57 * Explicitly declare the entity api name.
59 public function getDefaultEntity() {
63 public function preProcess() {
66 $this->_context
= CRM_Utils_Request
::retrieve('context', 'String', $this);
68 $this->assign('context', $this->_context
);
70 $this->_action
= CRM_Utils_Request
::retrieve('action', 'String', $this);
72 if ($this->_action
& CRM_Core_Action
::UPDATE
) {
73 CRM_Utils_System
::setTitle(ts('Configure Survey') . ' - ' . $this->_surveyTitle
);
76 // when custom data is included in this page
77 if (!empty($_POST['hidden_custom'])) {
78 CRM_Custom_Form_CustomData
::preProcess($this);
79 CRM_Custom_Form_CustomData
::buildQuickForm($this);
82 if ($this->_name
!= 'Petition') {
83 $url = CRM_Utils_System
::url('civicrm/campaign', 'reset=1&subPage=survey');
84 CRM_Utils_System
::appendBreadCrumb(array(array('title' => ts('Survey Dashboard'), 'url' => $url)));
87 $this->_values
= $this->get('values');
88 if (!is_array($this->_values
)) {
89 $this->_values
= array();
90 if ($this->_surveyId
) {
91 $params = array('id' => $this->_surveyId
);
92 CRM_Campaign_BAO_Survey
::retrieve($params, $this->_values
);
94 $this->set('values', $this->_values
);
97 $this->assign('action', $this->_action
);
98 $this->assign('surveyId', $this->_surveyId
);
100 $this->assign('entityID', $this->_surveyId
);
104 * Set default values for the form. Note that in edit/view mode
105 * the default values are retrieved from the database
108 * array of default values
110 public function setDefaultValues() {
112 $defaults = $this->_values
;
114 if ($this->_surveyId
) {
116 if (!empty($defaults['result_id']) && !empty($defaults['recontact_interval'])) {
118 $resultId = $defaults['result_id'];
119 $recontactInterval = unserialize($defaults['recontact_interval']);
121 unset($defaults['recontact_interval']);
122 $defaults['option_group_id'] = $resultId;
126 if (!isset($defaults['is_active'])) {
127 $defaults['is_active'] = 1;
130 $defaultSurveys = CRM_Campaign_BAO_Survey
::getSurveys(TRUE, TRUE);
131 if (!isset($defaults['is_default']) && empty($defaultSurveys)) {
132 $defaults['is_default'] = 1;
139 * Build the form object.
143 public function buildQuickForm() {
145 $this->add('text', 'title', ts('Title'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'title'), TRUE);
147 $surveyActivityTypes = CRM_Campaign_BAO_Survey
::getSurveyActivityType();
149 $this->addSelect('activity_type_id', array('option_url' => 'civicrm/admin/campaign/surveyType'), TRUE);
152 $campaigns = CRM_Campaign_BAO_Campaign
::getCampaigns(CRM_Utils_Array
::value('campaign_id', $this->_values
));
153 $this->add('select', 'campaign_id', ts('Campaign'), array('' => ts('- select -')) +
$campaigns);
155 // script / instructions
156 $this->add('wysiwyg', 'instructions', ts('Instructions for interviewers'), array('rows' => 5, 'cols' => 40));
159 $this->add('text', 'release_frequency', ts('Release Frequency'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'release_frequency'));
161 $this->addRule('release_frequency', ts('Release Frequency interval should be a positive number.'), 'positiveInteger');
163 // max reserved contacts at a time
164 $this->add('text', 'default_number_of_contacts', ts('Maximum reserved at one time'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'default_number_of_contacts'));
165 $this->addRule('default_number_of_contacts', ts('Maximum reserved at one time should be a positive number'), 'positiveInteger');
167 // total reserved per interviewer
168 $this->add('text', 'max_number_of_contacts', ts('Total reserved per interviewer'), CRM_Core_DAO
::getAttribute('CRM_Campaign_DAO_Survey', 'max_number_of_contacts'));
169 $this->addRule('max_number_of_contacts', ts('Total reserved contacts should be a positive number'), 'positiveInteger');
172 $this->add('checkbox', 'is_active', ts('Active?'));
175 $this->add('checkbox', 'is_default', ts('Default?'));
177 parent
::buildQuickForm();
185 public function postProcess() {
186 // store the submitted values in an array
187 $params = $this->controller
->exportValues($this->_name
);
189 $session = CRM_Core_Session
::singleton();
191 $params['last_modified_id'] = $session->get('userID');
192 $params['last_modified_date'] = date('YmdHis');
194 if ($this->_surveyId
) {
195 $params['id'] = $this->_surveyId
;
198 $params['created_id'] = $session->get('userID');
199 $params['created_date'] = date('YmdHis');
202 $params['is_active'] = CRM_Utils_Array
::value('is_active', $params, 0);
203 $params['is_default'] = CRM_Utils_Array
::value('is_default', $params, 0);
205 $params['custom'] = CRM_Core_BAO_CustomField
::postProcess($params,
209 $survey = CRM_Campaign_BAO_Survey
::create($params);
210 $this->_surveyId
= $survey->id
;
212 if (!empty($this->_values
['result_id'])) {
213 $query = "SELECT COUNT(*) FROM civicrm_survey WHERE result_id = %1";
214 $countSurvey = (int) CRM_Core_DAO
::singleValueQuery($query,
217 $this->_values
['result_id'],
222 // delete option group if no any survey is using it.
224 CRM_Core_BAO_OptionGroup
::del($this->_values
['result_id']);
228 parent
::endPostProcess();