3 +--------------------------------------------------------------------+
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2019 |
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-2019
35 * This class generates form components for building activity to a case.
37 class CRM_Case_Form_ActivityToCase
extends CRM_Core_Form
{
40 * Build all the data structures needed to build the form.
42 public function preProcess() {
43 $this->_activityId
= CRM_Utils_Request
::retrieve('activityId', 'Positive');
44 if (!$this->_activityId
) {
45 CRM_Core_Error
::fatal('required activity id is missing.');
48 $this->_currentCaseId
= CRM_Utils_Request
::retrieve('caseId', 'Positive');
49 $this->assign('currentCaseId', $this->_currentCaseId
);
50 $this->assign('buildCaseActivityForm', TRUE);
52 switch (CRM_Utils_Request
::retrieve('fileOnCaseAction', 'String')) {
54 CRM_Utils_System
::setTitle(ts('Move to Case'));
58 CRM_Utils_System
::setTitle(ts('Copy to Case'));
65 * Set default values for the form. For edit/view mode
66 * the default values are retrieved from the database
71 public function setDefaultValues() {
73 $params = ['id' => $this->_activityId
];
75 CRM_Activity_BAO_Activity
::retrieve($params, $defaults);
76 $defaults['file_on_case_activity_subject'] = $defaults['subject'];
77 $defaults['file_on_case_target_contact_id'] = $defaults['target_contact'];
79 // If this contact has an open case, supply it as a default
80 $cid = CRM_Utils_Request
::retrieve('cid', 'Integer');
82 $act = civicrm_api3('Activity', 'getsingle', ['id' => $this->_activityId
, 'return' => 'target_contact_id']);
83 if (!empty($act['target_contact_id'])) {
84 $cid = $act['target_contact_id'][0];
88 $cases = civicrm_api3('CaseContact', 'get', [
90 'case_id' => ['!=' => $this->_currentCaseId
],
91 'case_id.status_id' => ['!=' => "Closed"],
92 'case_id.is_deleted' => 0,
93 'case_id.end_date' => ['IS NULL' => 1],
94 'options' => ['limit' => 1],
95 'return' => 'case_id',
97 foreach ($cases['values'] as $record) {
98 $defaults['file_on_case_unclosed_case_id'] = $record['case_id'];
106 * Build the form object.
108 public function buildQuickForm() {
109 $this->addEntityRef('file_on_case_unclosed_case_id', ts('Select Case'), [
112 'extra' => ['contact_id'],
114 'case_id' => ['!=' => $this->_currentCaseId
],
115 'case_id.is_deleted' => 0,
116 'case_id.status_id' => ['!=' => "Closed"],
117 'case_id.end_date' => ['IS NULL' => 1],
121 $this->addEntityRef('file_on_case_target_contact_id', ts('With Contact(s)'), ['multiple' => TRUE]);
122 $this->add('text', 'file_on_case_activity_subject', ts('Subject'), ['size' => 50]);