3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
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-2014
35 class CRM_Event_Page_ParticipantListing_Simple
extends CRM_Core_Page
{
39 protected $_participantListingType;
41 protected $_eventTitle;
45 function preProcess() {
46 $this->_id
= CRM_Utils_Request
::retrieve('id', 'Integer', $this, TRUE);
48 // retrieve Event Title and include it in page title
49 $this->_eventTitle
= CRM_Core_DAO
::getFieldValue('CRM_Event_DAO_Event',
53 CRM_Utils_System
::setTitle(ts('%1 - Participants', array(1 => $this->_eventTitle
)));
55 // we do not want to display recently viewed contacts since this is potentially a public page
56 $this->assign('displayRecent', FALSE);
67 INNER JOIN civicrm_participant ON ( civicrm_contact.id = civicrm_participant.contact_id
68 AND civicrm_contact.is_deleted = 0 )
69 INNER JOIN civicrm_event ON civicrm_participant.event_id = civicrm_event.id
70 LEFT JOIN civicrm_email ON ( civicrm_contact.id = civicrm_email.contact_id AND civicrm_email.is_primary = 1 )
74 WHERE civicrm_event.id = %1
75 AND civicrm_participant.is_test = 0
76 AND civicrm_participant.status_id IN ( 1, 2 )";
77 $params = array(1 => array($this->_id
, 'Integer'));
78 $this->pager($fromClause, $whereClause, $params);
79 $orderBy = $this->orderBy();
81 list($offset, $rowCount) = $this->_pager
->getOffsetAndRowCount();
84 SELECT civicrm_contact.id as contact_id ,
85 civicrm_contact.display_name as name ,
86 civicrm_contact.sort_name as sort_name ,
87 civicrm_participant.id as participant_id,
88 civicrm_email.email as email
92 LIMIT $offset, $rowCount";
95 $object = CRM_Core_DAO
::executeQuery($query, $params);
96 while ($object->fetch()) {
98 'id' => $object->contact_id
,
99 'participantID' => $object->participant_id
,
100 'name' => $object->name
,
101 'email' => $object->email
,
105 $this->assign_by_ref('rows', $rows);
107 return parent
::run();
112 * @param $whereClause
113 * @param $whereParams
115 function pager($fromClause, $whereClause, $whereParams) {
119 $params['status'] = ts('Group') . ' %%StatusMessage%%';
120 $params['csvString'] = NULL;
121 $params['buttonTop'] = 'PagerTopButton';
122 $params['buttonBottom'] = 'PagerBottomButton';
123 $params['rowCount'] = $this->get(CRM_Utils_Pager
::PAGE_ROWCOUNT
);
124 if (!$params['rowCount']) {
125 $params['rowCount'] = CRM_Utils_Pager
::ROWCOUNT
;
129 SELECT count( civicrm_contact.id )
134 $params['total'] = CRM_Core_DAO
::singleValueQuery($query, $whereParams);
135 $this->_pager
= new CRM_Utils_Pager($params);
136 $this->assign_by_ref('pager', $this->_pager
);
143 static $headers = NULL;
146 $headers[1] = array('name' => ts('Name'),
147 'sort' => 'civicrm_contact.sort_name',
148 'direction' => CRM_Utils_Sort
::ASCENDING
,
150 if ($this->_participantListingType
== 'Name and Email') {
151 $headers[2] = array('name' => ts('Email'),
152 'sort' => 'civicrm_email.email',
153 'direction' => CRM_Utils_Sort
::DONTCARE
,
158 if ($this->get(CRM_Utils_Sort
::SORT_ID
)) {
159 $sortID = CRM_Utils_Sort
::sortIDValue($this->get(CRM_Utils_Sort
::SORT_ID
),
160 $this->get(CRM_Utils_Sort
::SORT_DIRECTION
)
163 $sort = new CRM_Utils_Sort($headers, $sortID);
164 $this->assign_by_ref('headers', $headers);
165 $this->assign_by_ref('sort', $sort);
166 $this->set(CRM_Utils_Sort
::SORT_ID
,
167 $sort->getCurrentSortID()
169 $this->set(CRM_Utils_Sort
::SORT_DIRECTION
,
170 $sort->getCurrentSortDirection()
173 return $sort->orderBy();