Merge pull request #6806 from colemanw/CRM-16980
[civicrm-core.git] / CRM / Case / Form / ActivityToCase.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
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 */
33
34 /**
35 * This class generates form components for building activity to a case.
36 */
37 class CRM_Case_Form_ActivityToCase extends CRM_Core_Form {
38
39 /**
40 * Build all the data structures needed to build the form.
41 */
42 public function preProcess() {
43 $this->_activityId = CRM_Utils_Request::retrieve('activityId', 'Positive', CRM_Core_DAO::$_nullObject);
44 if (!$this->_activityId) {
45 CRM_Core_Error::fatal('required activity id is missing.');
46 }
47
48 $this->_currentCaseId = CRM_Utils_Request::retrieve('caseId', 'Positive', CRM_Core_DAO::$_nullObject);
49 $this->assign('currentCaseId', $this->_currentCaseId);
50 $this->assign('buildCaseActivityForm', TRUE);
51 }
52
53 /**
54 * Set default values for the form. For edit/view mode
55 * the default values are retrieved from the database
56 *
57 *
58 * @return array
59 */
60 public function setDefaultValues() {
61 $defaults = array();
62 $params = array('id' => $this->_activityId);
63
64 CRM_Activity_BAO_Activity::retrieve($params, $defaults);
65 $defaults['file_on_case_activity_subject'] = $defaults['subject'];
66 $defaults['file_on_case_target_contact_id'] = $defaults['target_contact'];
67
68 // If this contact has an open case, supply it as a default
69 $cid = CRM_Utils_Request::retrieve('cid', 'Integer');
70 if ($cid) {
71 $cases = CRM_Case_BAO_Case::getUnclosedCases(array('contact_id' => $cid), $this->_currentCaseId);
72 foreach ($cases as $id => $details) {
73 $defaults['file_on_case_unclosed_case_id'] = $id;
74 $value = array(
75 'label' => $details['sort_name'] . ' - ' . $details['case_type'],
76 'extra' => array('contact_id' => $cid),
77 );
78 $this->updateElementAttr('file_on_case_unclosed_case_id', array('data-value' => json_encode($value)));
79 break;
80 }
81 }
82
83 return $defaults;
84 }
85
86 /**
87 * Build the form object.
88 */
89 public function buildQuickForm() {
90 $this->add('text', 'file_on_case_unclosed_case_id', ts('Select Case'), array('class' => 'huge'), TRUE);
91 $this->addEntityRef('file_on_case_target_contact_id', ts('With Contact(s)'), array('multiple' => TRUE));
92 $this->add('text', 'file_on_case_activity_subject', ts('Subject'), array('size' => 50));
93 }
94
95 }