commiting uncommited changes on live site
[weblabels.fsf.org.git] / crm.fsf.org / 20131203 / files / sites / all / modules-new / civicrm / CRM / Campaign / Form / Survey / Main.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2015 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
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. |
13 | |
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. |
18 | |
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 +--------------------------------------------------------------------+
26 */
27
28 /**
29 *
30 * @package CRM
31 * @copyright CiviCRM LLC (c) 2004-2015
32 * $Id$
33 *
34 */
35
36 /**
37 * This class generates form components for processing a survey
38 *
39 */
40 class CRM_Campaign_Form_Survey_Main extends CRM_Campaign_Form_Survey {
41
42 /* values
43 *
44 * @var array
45 */
46
47 public $_values;
48
49 /**
50 * Context.
51 *
52 * @var string
53 */
54 protected $_context;
55
56 public function preProcess() {
57 parent::preProcess();
58
59 $this->_context = CRM_Utils_Request::retrieve('context', 'String', $this);
60
61 $this->assign('context', $this->_context);
62
63 $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this);
64
65 if ($this->_action & CRM_Core_Action::UPDATE) {
66 CRM_Utils_System::setTitle(ts('Configure Survey') . ' - ' . $this->_surveyTitle);
67 }
68
69 $this->_cdType = CRM_Utils_Array::value('type', $_GET);
70 $this->assign('cdType', FALSE);
71 if ($this->_cdType) {
72 $this->assign('cdType', TRUE);
73 return CRM_Custom_Form_CustomData::preProcess($this);
74 }
75
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);
80 }
81
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)));
85 }
86
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);
93 }
94 $this->set('values', $this->_values);
95 }
96
97 $this->assign('action', $this->_action);
98 $this->assign('surveyId', $this->_surveyId);
99 // for custom data
100 $this->assign('entityID', $this->_surveyId);
101 }
102
103 /**
104 * Set default values for the form. Note that in edit/view mode
105 * the default values are retrieved from the database
106 *
107 * @return array
108 * array of default values
109 */
110 public function setDefaultValues() {
111 if ($this->_cdType) {
112 return CRM_Custom_Form_CustomData::setDefaultValues($this);
113 }
114
115 $defaults = $this->_values;
116
117 if ($this->_surveyId) {
118
119 if (!empty($defaults['result_id']) && !empty($defaults['recontact_interval'])) {
120
121 $resultId = $defaults['result_id'];
122 $recontactInterval = unserialize($defaults['recontact_interval']);
123
124 unset($defaults['recontact_interval']);
125 $defaults['option_group_id'] = $resultId;
126 }
127 }
128
129 if (!isset($defaults['is_active'])) {
130 $defaults['is_active'] = 1;
131 }
132
133 $defaultSurveys = CRM_Campaign_BAO_Survey::getSurveys(TRUE, TRUE);
134 if (!isset($defaults['is_default']) && empty($defaultSurveys)) {
135 $defaults['is_default'] = 1;
136 }
137
138 return $defaults;
139 }
140
141 /**
142 * Build the form object.
143 *
144 * @return void
145 */
146 public function buildQuickForm() {
147 if ($this->_cdType) {
148 return CRM_Custom_Form_CustomData::buildQuickForm($this);
149 }
150
151 $this->add('text', 'title', ts('Title'), CRM_Core_DAO::getAttribute('CRM_Campaign_DAO_Survey', 'title'), TRUE);
152
153 $surveyActivityTypes = CRM_Campaign_BAO_Survey::getSurveyActivityType();
154 // Activity Type id
155 $this->addSelect('activity_type_id', array('option_url' => 'civicrm/admin/campaign/surveyType'), TRUE);
156
157 // Campaign id
158 $campaigns = CRM_Campaign_BAO_Campaign::getCampaigns(CRM_Utils_Array::value('campaign_id', $this->_values));
159 $this->add('select', 'campaign_id', ts('Campaign'), array('' => ts('- select -')) + $campaigns);
160
161 // script / instructions
162 $this->addWysiwyg('instructions', ts('Instructions for interviewers'), array('rows' => 5, 'cols' => 40));
163
164 // release frequency
165 $this->add('text', 'release_frequency', ts('Release Frequency'), CRM_Core_DAO::getAttribute('CRM_Campaign_DAO_Survey', 'release_frequency'));
166
167 $this->addRule('release_frequency', ts('Release Frequency interval should be a positive number.'), 'positiveInteger');
168
169 // max reserved contacts at a time
170 $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'));
171 $this->addRule('default_number_of_contacts', ts('Maximum reserved at one time should be a positive number'), 'positiveInteger');
172
173 // total reserved per interviewer
174 $this->add('text', 'max_number_of_contacts', ts('Total reserved per interviewer'), CRM_Core_DAO::getAttribute('CRM_Campaign_DAO_Survey', 'max_number_of_contacts'));
175 $this->addRule('max_number_of_contacts', ts('Total reserved contacts should be a positive number'), 'positiveInteger');
176
177 // is active ?
178 $this->add('checkbox', 'is_active', ts('Active?'));
179
180 // is default ?
181 $this->add('checkbox', 'is_default', ts('Default?'));
182
183 parent::buildQuickForm();
184 }
185
186 /**
187 * Process the form.
188 *
189 * @return void
190 */
191 public function postProcess() {
192 // store the submitted values in an array
193 $params = $this->controller->exportValues($this->_name);
194
195 $session = CRM_Core_Session::singleton();
196
197 $params['last_modified_id'] = $session->get('userID');
198 $params['last_modified_date'] = date('YmdHis');
199
200 if ($this->_surveyId) {
201 $params['id'] = $this->_surveyId;
202 }
203 else {
204 $params['created_id'] = $session->get('userID');
205 $params['created_date'] = date('YmdHis');
206 }
207
208 $params['is_active'] = CRM_Utils_Array::value('is_active', $params, 0);
209 $params['is_default'] = CRM_Utils_Array::value('is_default', $params, 0);
210
211 $params['custom'] = CRM_Core_BAO_CustomField::postProcess($params,
212 $customFields,
213 $this->_surveyId,
214 'Survey'
215 );
216 $survey = CRM_Campaign_BAO_Survey::create($params);
217 $this->_surveyId = $survey->id;
218
219 if (!empty($this->_values['result_id'])) {
220 $query = "SELECT COUNT(*) FROM civicrm_survey WHERE result_id = %1";
221 $countSurvey = (int) CRM_Core_DAO::singleValueQuery($query,
222 array(
223 1 => array(
224 $this->_values['result_id'],
225 'Positive',
226 ),
227 )
228 );
229 // delete option group if no any survey is using it.
230 if (!$countSurvey) {
231 CRM_Core_BAO_OptionGroup::del($this->_values['result_id']);
232 }
233 }
234
235 parent::endPostProcess();
236 }
237
238 }