Commit | Line | Data |
---|---|---|
6a488035 TO |
1 | <?php |
2 | /* | |
3 | +--------------------------------------------------------------------+ | |
232624b1 | 4 | | CiviCRM version 4.4 | |
6a488035 TO |
5 | +--------------------------------------------------------------------+ |
6 | | Copyright CiviCRM LLC (c) 2004-2013 | | |
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-2013 | |
32 | * $Id$ | |
33 | * | |
34 | */ | |
35 | class CRM_Contact_Page_View_Relationship extends CRM_Core_Page { | |
36 | ||
37 | /** | |
38 | * The action links that we need to display for the browse screen | |
39 | * | |
40 | * @var array | |
41 | * @static | |
42 | */ | |
43 | static $_links = NULL; | |
44 | ||
45 | /** | |
46 | * casid set if called from case context | |
47 | * | |
48 | * @var int | |
49 | */ | |
50 | public $_caseId = NULL; | |
51 | ||
52 | public $_permission = NULL; | |
53 | public $_contactId = NULL; | |
54 | ||
55 | /** | |
56 | * View details of a relationship | |
57 | * | |
58 | * @return void | |
59 | * | |
60 | * @access public | |
61 | */ | |
62 | function view() { | |
63 | $viewRelationship = CRM_Contact_BAO_Relationship::getRelationship($this->_contactId, NULL, NULL, NULL, $this->_id); | |
64 | //To check whether selected contact is a contact_id_a in | |
65 | //relationship type 'a_b' in relationship table, if yes then | |
66 | //revert the permissionship text in template | |
67 | $relationship = new CRM_Contact_DAO_Relationship(); | |
68 | $relationship->id = $viewRelationship[$this->_id]['id']; | |
69 | ||
70 | if ($relationship->find(TRUE)) { | |
71 | if (($viewRelationship[$this->_id]['rtype'] == 'a_b') && ($this->_contactId == $relationship->contact_id_a)) { | |
72 | $this->assign("is_contact_id_a", TRUE); | |
73 | } | |
74 | } | |
75 | $relType = $viewRelationship[$this->_id]['civicrm_relationship_type_id']; | |
76 | $this->assign('viewRelationship', $viewRelationship); | |
77 | ||
78 | $employerId = CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact', $this->_contactId, 'employer_id'); | |
79 | $this->assign('isCurrentEmployer', FALSE); | |
05802b8e DG |
80 | |
81 | $relTypes = CRM_Utils_Array::index(array('name_a_b'), CRM_Core_PseudoConstant::relationshipType('name')); | |
82 | ||
6a488035 TO |
83 | if ($viewRelationship[$this->_id]['employer_id'] == $this->_contactId) { |
84 | $this->assign('isCurrentEmployer', TRUE); | |
85 | } | |
05802b8e | 86 | elseif ($relType == $relTypes['Employee of']['id'] && |
6a488035 TO |
87 | ($viewRelationship[$this->_id]['cid'] == $employerId) |
88 | ) { | |
89 | // make sure we are viewing employee of relationship | |
90 | $this->assign('isCurrentEmployer', TRUE); | |
91 | } | |
92 | ||
93 | $viewNote = CRM_Core_BAO_Note::getNote($this->_id); | |
94 | $this->assign('viewNote', $viewNote); | |
95 | ||
96 | $groupTree = CRM_Core_BAO_CustomGroup::getTree('Relationship', $this, $this->_id, 0, $relType); | |
97 | CRM_Core_BAO_CustomGroup::buildCustomDataView($this, $groupTree); | |
98 | ||
99 | $rType = CRM_Utils_Array::value('rtype', $viewRelationship[$this->_id]); | |
100 | // add viewed contribution to recent items list | |
101 | $url = CRM_Utils_System::url('civicrm/contact/view/rel', | |
102 | "action=view&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&context=home" | |
103 | ); | |
104 | ||
105 | ||
106 | $session = CRM_Core_Session::singleton(); | |
107 | $recentOther = array(); | |
108 | ||
109 | if (($session->get('userID') == $this->_contactId) || | |
110 | CRM_Contact_BAO_Contact_Permission::allow($this->_contactId, CRM_Core_Permission::EDIT) | |
111 | ) { | |
112 | $recentOther = array( | |
113 | 'editUrl' => CRM_Utils_System::url('civicrm/contact/view/rel', | |
114 | "action=update&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&rtype={$rType}&context=home" | |
115 | ), | |
116 | 'deleteUrl' => CRM_Utils_System::url('civicrm/contact/view/rel', | |
117 | "action=delete&reset=1&id={$viewRelationship[$this->_id]['id']}&cid={$this->_contactId}&rtype={$rType}&context=home" | |
118 | ), | |
119 | ); | |
120 | } | |
121 | ||
122 | $displayName = CRM_Contact_BAO_Contact::displayName($this->_contactId); | |
123 | $this->assign('displayName', $displayName); | |
124 | CRM_Utils_System::setTitle(ts('View Relationship for') . ' ' . $displayName); | |
125 | ||
126 | $title = $displayName . ' (' . $viewRelationship[$this->_id]['relation'] . ' ' . CRM_Contact_BAO_Contact::displayName($viewRelationship[$this->_id]['cid']) . ')'; | |
127 | ||
128 | // add the recently viewed Relationship | |
129 | CRM_Utils_Recent::add($title, | |
130 | $url, | |
131 | $viewRelationship[$this->_id]['id'], | |
132 | 'Relationship', | |
133 | $this->_contactId, | |
134 | NULL, | |
135 | $recentOther | |
136 | ); | |
137 | } | |
138 | ||
139 | /** | |
140 | * This function is called when action is browse | |
141 | * | |
142 | * return null | |
143 | * @access public | |
144 | */ | |
145 | function browse() { | |
146 | $links = self::links(); | |
147 | ||
148 | //CRM-4418, handling edit and delete separately. | |
149 | $permissions = array($this->_permission); | |
150 | if ($this->_permission == CRM_Core_Permission::EDIT) { | |
151 | //previously delete was subset of edit | |
152 | //so for consistency lets grant delete also. | |
153 | $permissions[] = CRM_Core_Permission::DELETE; | |
154 | } | |
155 | $mask = CRM_Core_Action::mask($permissions); | |
156 | ||
157 | $currentRelationships = CRM_Contact_BAO_Relationship::getRelationship($this->_contactId, | |
158 | CRM_Contact_BAO_Relationship::CURRENT, | |
159 | 0, 0, 0, | |
160 | $links, $mask | |
161 | ); | |
162 | ||
163 | $inactiveRelationships = CRM_Contact_BAO_Relationship::getRelationship($this->_contactId, | |
164 | CRM_Contact_BAO_Relationship::INACTIVE, | |
165 | 0, 0, 0, | |
166 | $links, $mask | |
167 | ); | |
168 | ||
169 | $this->assign('currentRelationships', $currentRelationships); | |
170 | // to show the 'Current Relationships' title and links only when viewed | |
171 | // from relationship tab, not from dashboard | |
172 | $this->assign('relationshipTabContext', TRUE); | |
173 | $this->assign('inactiveRelationships', $inactiveRelationships); | |
4e8065a9 CW |
174 | |
175 | $this->ajaxResponse['tabCount'] = count($currentRelationships); | |
6a488035 TO |
176 | } |
177 | ||
178 | /** | |
179 | * This function is called when action is update or new | |
180 | * | |
181 | * return null | |
182 | * @access public | |
183 | */ | |
184 | function edit() { | |
185 | $controller = new CRM_Core_Controller_Simple('CRM_Contact_Form_Relationship', ts('Contact Relationships'), $this->_action); | |
186 | $controller->setEmbedded(TRUE); | |
187 | ||
188 | // set the userContext stack | |
189 | $session = CRM_Core_Session::singleton(); | |
190 | ||
191 | // if this is called from case view, we need to redirect back to same page | |
192 | if ($this->_caseId) { | |
193 | $url = CRM_Utils_System::url('civicrm/contact/view/case', "action=view&reset=1&cid={$this->_contactId}&id={$this->_caseId}"); | |
194 | } | |
195 | else { | |
196 | $url = CRM_Utils_System::url('civicrm/contact/view', "action=browse&selectedChild=rel&reset=1&cid={$this->_contactId}"); | |
197 | } | |
198 | ||
199 | $session->pushUserContext($url); | |
200 | ||
201 | if (CRM_Utils_Request::retrieve('confirmed', 'Boolean', | |
202 | CRM_Core_DAO::$_nullObject | |
203 | )) { | |
204 | if ($this->_caseId) { | |
205 | //create an activity for case role removal.CRM-4480 | |
206 | CRM_Case_BAO_Case::createCaseRoleActivity($this->_caseId, $this->_id); | |
207 | CRM_Core_Session::setStatus(ts('Case Role has been deleted successfully.'), ts('Record Deleted'), 'success'); | |
208 | } | |
209 | ||
210 | // delete relationship | |
211 | CRM_Contact_BAO_Relationship::del($this->_id); | |
212 | ||
213 | CRM_Utils_System::redirect($url); | |
214 | } | |
215 | ||
216 | $controller->set('contactId', $this->_contactId); | |
217 | $controller->set('id', $this->_id); | |
218 | $controller->process(); | |
219 | $controller->run(); | |
220 | } | |
221 | ||
222 | function preProcess() { | |
223 | $this->_id = CRM_Utils_Request::retrieve('id', 'Positive', $this); | |
224 | $this->_contactId = CRM_Utils_Request::retrieve('cid', 'Positive', $this, TRUE); | |
225 | $this->assign('contactId', $this->_contactId); | |
226 | ||
227 | // check logged in url permission | |
228 | CRM_Contact_Page_View::checkUserPermission($this); | |
229 | ||
230 | // set page title | |
231 | CRM_Contact_Page_View::setTitle($this->_contactId); | |
232 | ||
233 | $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this, FALSE, 'browse'); | |
234 | $this->assign('action', $this->_action); | |
235 | } | |
236 | ||
237 | /** | |
238 | * This function is the main function that is called when the page loads, | |
239 | * it decides the which action has to be taken for the page. | |
240 | * | |
241 | * return null | |
242 | * @access public | |
243 | */ | |
244 | function run() { | |
245 | $this->preProcess(); | |
246 | ||
247 | $this->setContext(); | |
248 | ||
249 | $this->_caseId = CRM_Utils_Request::retrieve('caseID', 'Integer', $this); | |
250 | ||
251 | if ($this->_action & CRM_Core_Action::VIEW) { | |
252 | $this->view(); | |
253 | } | |
254 | elseif ($this->_action & (CRM_Core_Action::UPDATE | CRM_Core_Action::ADD | CRM_Core_Action::DELETE)) { | |
255 | $this->edit(); | |
256 | } | |
257 | elseif ($this->_action & CRM_Core_Action::DISABLE) { | |
258 | CRM_Contact_BAO_Relationship::disableEnableRelationship($this->_id, CRM_Core_Action::DISABLE); | |
259 | CRM_Contact_BAO_Relationship::setIsActive($this->_id, 0); | |
260 | $session = CRM_Core_Session::singleton(); | |
261 | CRM_Utils_System::redirect($session->popUserContext()); | |
262 | } | |
263 | elseif ($this->_action & CRM_Core_Action::ENABLE) { | |
264 | CRM_Contact_BAO_Relationship::disableEnableRelationship($this->_id, CRM_Core_Action::ENABLE); | |
265 | CRM_Contact_BAO_Relationship::setIsActive($this->_id, 1); | |
266 | $session = CRM_Core_Session::singleton(); | |
267 | CRM_Utils_System::redirect($session->popUserContext()); | |
268 | } | |
269 | ||
270 | // if this is called from case view, suppress browse relationships form | |
babae7c3 | 271 | else { |
6a488035 TO |
272 | $this->browse(); |
273 | } | |
274 | ||
275 | return parent::run(); | |
276 | } | |
277 | ||
278 | function setContext() { | |
279 | $context = CRM_Utils_Request::retrieve('context', 'String', | |
280 | $this, FALSE, 'search' | |
281 | ); | |
282 | ||
283 | if ($context == 'dashboard') { | |
284 | $cid = CRM_Utils_Request::retrieve('cid', 'Integer', | |
285 | $this, FALSE | |
286 | ); | |
287 | $url = CRM_Utils_System::url('civicrm/user', | |
288 | "reset=1&id={$cid}" | |
289 | ); | |
290 | } | |
291 | else { | |
292 | $url = CRM_Utils_System::url('civicrm/contact/view', 'action=browse&selectedChild=rel'); | |
293 | } | |
294 | $session = CRM_Core_Session::singleton(); | |
295 | $session->pushUserContext($url); | |
296 | } | |
297 | ||
298 | /** | |
299 | * This function is called to delete the relationship of a contact | |
300 | * | |
301 | * return null | |
302 | * @access public | |
303 | */ | |
304 | function delete() { | |
305 | // calls a function to delete relationship | |
306 | CRM_Contact_BAO_Relationship::del($this->_id); | |
307 | } | |
308 | ||
309 | /** | |
310 | * Get action links | |
311 | * | |
312 | * @return array (reference) of action links | |
313 | * @static | |
314 | */ | |
315 | static function &links() { | |
316 | if (!(self::$_links)) { | |
6a488035 TO |
317 | self::$_links = array( |
318 | CRM_Core_Action::VIEW => array( | |
319 | 'name' => ts('View'), | |
320 | 'url' => 'civicrm/contact/view/rel', | |
321 | 'qs' => 'action=view&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%&selectedChild=rel', | |
322 | 'title' => ts('View Relationship'), | |
323 | ), | |
324 | CRM_Core_Action::UPDATE => array( | |
325 | 'name' => ts('Edit'), | |
326 | 'url' => 'civicrm/contact/view/rel', | |
327 | 'qs' => 'action=update&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%', | |
328 | 'title' => ts('Edit Relationship'), | |
329 | ), | |
330 | CRM_Core_Action::ENABLE => array( | |
331 | 'name' => ts('Enable'), | |
41b47b8a | 332 | 'ref' => 'crm-enable-disable', |
6a488035 TO |
333 | 'title' => ts('Enable Relationship'), |
334 | ), | |
335 | CRM_Core_Action::DISABLE => array( | |
336 | 'name' => ts('Disable'), | |
41b47b8a | 337 | 'ref' => 'crm-enable-disable', |
6a488035 TO |
338 | 'title' => ts('Disable Relationship'), |
339 | ), | |
340 | CRM_Core_Action::DELETE => array( | |
341 | 'name' => ts('Delete'), | |
342 | 'url' => 'civicrm/contact/view/rel', | |
343 | 'qs' => 'action=delete&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%', | |
6a488035 TO |
344 | 'title' => ts('Delete Relationship'), |
345 | ), | |
346 | // FIXME: Not sure what to put as the key. | |
347 | // We want to use it differently later anyway (see CRM_Contact_BAO_Relationship::getRelationship). NONE should make it hidden by default. | |
348 | CRM_Core_Action::NONE => array( | |
349 | 'name' => ts('Manage Case'), | |
350 | 'url' => 'civicrm/contact/view/case', | |
351 | 'qs' => 'action=view&reset=1&cid=%%clientid%%&id=%%caseid%%', | |
352 | 'title' => ts('Manage Case'), | |
353 | ), | |
354 | ); | |
355 | } | |
356 | return self::$_links; | |
357 | } | |
358 | } | |
359 |