Commit | Line | Data |
---|---|---|
6a488035 TO |
1 | <?php |
2 | /* | |
3 | +--------------------------------------------------------------------+ | |
06b69b18 | 4 | | CiviCRM version 4.5 | |
6a488035 | 5 | +--------------------------------------------------------------------+ |
06b69b18 | 6 | | Copyright CiviCRM LLC (c) 2004-2014 | |
6a488035 TO |
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 | |
06b69b18 | 31 | * @copyright CiviCRM LLC (c) 2004-2014 |
6a488035 TO |
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() { | |
40458f6c | 146 | // do nothing :) we are using datatable for rendering relationship selectors |
6a488035 TO |
147 | } |
148 | ||
149 | /** | |
150 | * This function is called when action is update or new | |
151 | * | |
152 | * return null | |
153 | * @access public | |
154 | */ | |
155 | function edit() { | |
156 | $controller = new CRM_Core_Controller_Simple('CRM_Contact_Form_Relationship', ts('Contact Relationships'), $this->_action); | |
157 | $controller->setEmbedded(TRUE); | |
158 | ||
159 | // set the userContext stack | |
160 | $session = CRM_Core_Session::singleton(); | |
161 | ||
162 | // if this is called from case view, we need to redirect back to same page | |
163 | if ($this->_caseId) { | |
164 | $url = CRM_Utils_System::url('civicrm/contact/view/case', "action=view&reset=1&cid={$this->_contactId}&id={$this->_caseId}"); | |
165 | } | |
166 | else { | |
167 | $url = CRM_Utils_System::url('civicrm/contact/view', "action=browse&selectedChild=rel&reset=1&cid={$this->_contactId}"); | |
168 | } | |
169 | ||
170 | $session->pushUserContext($url); | |
171 | ||
172 | if (CRM_Utils_Request::retrieve('confirmed', 'Boolean', | |
173 | CRM_Core_DAO::$_nullObject | |
174 | )) { | |
175 | if ($this->_caseId) { | |
176 | //create an activity for case role removal.CRM-4480 | |
177 | CRM_Case_BAO_Case::createCaseRoleActivity($this->_caseId, $this->_id); | |
178 | CRM_Core_Session::setStatus(ts('Case Role has been deleted successfully.'), ts('Record Deleted'), 'success'); | |
179 | } | |
180 | ||
181 | // delete relationship | |
182 | CRM_Contact_BAO_Relationship::del($this->_id); | |
183 | ||
184 | CRM_Utils_System::redirect($url); | |
185 | } | |
186 | ||
187 | $controller->set('contactId', $this->_contactId); | |
188 | $controller->set('id', $this->_id); | |
189 | $controller->process(); | |
190 | $controller->run(); | |
191 | } | |
192 | ||
193 | function preProcess() { | |
194 | $this->_id = CRM_Utils_Request::retrieve('id', 'Positive', $this); | |
195 | $this->_contactId = CRM_Utils_Request::retrieve('cid', 'Positive', $this, TRUE); | |
196 | $this->assign('contactId', $this->_contactId); | |
197 | ||
198 | // check logged in url permission | |
199 | CRM_Contact_Page_View::checkUserPermission($this); | |
200 | ||
201 | // set page title | |
202 | CRM_Contact_Page_View::setTitle($this->_contactId); | |
203 | ||
204 | $this->_action = CRM_Utils_Request::retrieve('action', 'String', $this, FALSE, 'browse'); | |
205 | $this->assign('action', $this->_action); | |
206 | } | |
207 | ||
208 | /** | |
209 | * This function is the main function that is called when the page loads, | |
210 | * it decides the which action has to be taken for the page. | |
211 | * | |
212 | * return null | |
213 | * @access public | |
214 | */ | |
215 | function run() { | |
216 | $this->preProcess(); | |
217 | ||
218 | $this->setContext(); | |
219 | ||
220 | $this->_caseId = CRM_Utils_Request::retrieve('caseID', 'Integer', $this); | |
221 | ||
222 | if ($this->_action & CRM_Core_Action::VIEW) { | |
223 | $this->view(); | |
224 | } | |
225 | elseif ($this->_action & (CRM_Core_Action::UPDATE | CRM_Core_Action::ADD | CRM_Core_Action::DELETE)) { | |
226 | $this->edit(); | |
227 | } | |
228 | elseif ($this->_action & CRM_Core_Action::DISABLE) { | |
229 | CRM_Contact_BAO_Relationship::disableEnableRelationship($this->_id, CRM_Core_Action::DISABLE); | |
230 | CRM_Contact_BAO_Relationship::setIsActive($this->_id, 0); | |
231 | $session = CRM_Core_Session::singleton(); | |
232 | CRM_Utils_System::redirect($session->popUserContext()); | |
233 | } | |
234 | elseif ($this->_action & CRM_Core_Action::ENABLE) { | |
235 | CRM_Contact_BAO_Relationship::disableEnableRelationship($this->_id, CRM_Core_Action::ENABLE); | |
236 | CRM_Contact_BAO_Relationship::setIsActive($this->_id, 1); | |
237 | $session = CRM_Core_Session::singleton(); | |
238 | CRM_Utils_System::redirect($session->popUserContext()); | |
239 | } | |
240 | ||
241 | // if this is called from case view, suppress browse relationships form | |
babae7c3 | 242 | else { |
6a488035 TO |
243 | $this->browse(); |
244 | } | |
245 | ||
246 | return parent::run(); | |
247 | } | |
248 | ||
249 | function setContext() { | |
250 | $context = CRM_Utils_Request::retrieve('context', 'String', | |
251 | $this, FALSE, 'search' | |
252 | ); | |
253 | ||
254 | if ($context == 'dashboard') { | |
255 | $cid = CRM_Utils_Request::retrieve('cid', 'Integer', | |
256 | $this, FALSE | |
257 | ); | |
258 | $url = CRM_Utils_System::url('civicrm/user', | |
259 | "reset=1&id={$cid}" | |
260 | ); | |
261 | } | |
262 | else { | |
263 | $url = CRM_Utils_System::url('civicrm/contact/view', 'action=browse&selectedChild=rel'); | |
264 | } | |
265 | $session = CRM_Core_Session::singleton(); | |
266 | $session->pushUserContext($url); | |
267 | } | |
268 | ||
269 | /** | |
270 | * This function is called to delete the relationship of a contact | |
271 | * | |
272 | * return null | |
273 | * @access public | |
274 | */ | |
275 | function delete() { | |
276 | // calls a function to delete relationship | |
277 | CRM_Contact_BAO_Relationship::del($this->_id); | |
278 | } | |
279 | ||
280 | /** | |
281 | * Get action links | |
282 | * | |
283 | * @return array (reference) of action links | |
284 | * @static | |
285 | */ | |
286 | static function &links() { | |
287 | if (!(self::$_links)) { | |
6a488035 TO |
288 | self::$_links = array( |
289 | CRM_Core_Action::VIEW => array( | |
290 | 'name' => ts('View'), | |
291 | 'url' => 'civicrm/contact/view/rel', | |
292 | 'qs' => 'action=view&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%&selectedChild=rel', | |
293 | 'title' => ts('View Relationship'), | |
294 | ), | |
295 | CRM_Core_Action::UPDATE => array( | |
296 | 'name' => ts('Edit'), | |
297 | 'url' => 'civicrm/contact/view/rel', | |
298 | 'qs' => 'action=update&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%', | |
299 | 'title' => ts('Edit Relationship'), | |
300 | ), | |
301 | CRM_Core_Action::ENABLE => array( | |
302 | 'name' => ts('Enable'), | |
41b47b8a | 303 | 'ref' => 'crm-enable-disable', |
6a488035 TO |
304 | 'title' => ts('Enable Relationship'), |
305 | ), | |
306 | CRM_Core_Action::DISABLE => array( | |
307 | 'name' => ts('Disable'), | |
41b47b8a | 308 | 'ref' => 'crm-enable-disable', |
6a488035 TO |
309 | 'title' => ts('Disable Relationship'), |
310 | ), | |
311 | CRM_Core_Action::DELETE => array( | |
312 | 'name' => ts('Delete'), | |
313 | 'url' => 'civicrm/contact/view/rel', | |
314 | 'qs' => 'action=delete&reset=1&cid=%%cid%%&id=%%id%%&rtype=%%rtype%%', | |
6a488035 TO |
315 | 'title' => ts('Delete Relationship'), |
316 | ), | |
317 | // FIXME: Not sure what to put as the key. | |
318 | // We want to use it differently later anyway (see CRM_Contact_BAO_Relationship::getRelationship). NONE should make it hidden by default. | |
319 | CRM_Core_Action::NONE => array( | |
320 | 'name' => ts('Manage Case'), | |
321 | 'url' => 'civicrm/contact/view/case', | |
322 | 'qs' => 'action=view&reset=1&cid=%%clientid%%&id=%%caseid%%', | |
323 | 'title' => ts('Manage Case'), | |
324 | ), | |
325 | ); | |
326 | } | |
327 | return self::$_links; | |
328 | } | |
329 | } | |
330 |