Merge remote-tracking branch 'upstream/4.6' into 4.6-master-2015-08-24-22-26-45
[civicrm-core.git] / CRM / Admin / Page / EventTemplate.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 * $Id$
33 *
34 */
35
36 /**
37 * Page for displaying list of event templates.
38 */
39 class CRM_Admin_Page_EventTemplate extends CRM_Core_Page_Basic {
40
41 /**
42 * The action links that we need to display for the browse screen.
43 *
44 * @var array
45 */
46 static $_links = NULL;
47
48 /**
49 * Get BAO Name.
50 *
51 * @return string
52 * Classname of BAO.
53 */
54 public function getBAOName() {
55 return 'CRM_Event_BAO_Event';
56 }
57
58 /**
59 * Get action Links.
60 *
61 * @return array
62 * (reference) of action links
63 */
64 public function &links() {
65 if (!(self::$_links)) {
66 // helper variable for nicer formatting
67 self::$_links = array(
68 CRM_Core_Action::UPDATE => array(
69 'name' => ts('Edit'),
70 'url' => 'civicrm/event/manage/settings',
71 'qs' => 'action=update&id=%%id%%&reset=1',
72 'title' => ts('Edit Event Template'),
73 ),
74 CRM_Core_Action::DELETE => array(
75 'name' => ts('Delete'),
76 'url' => 'civicrm/event/manage',
77 'qs' => 'action=delete&id=%%id%%',
78 'title' => ts('Delete Event Template'),
79 ),
80 );
81 }
82
83 return self::$_links;
84 }
85
86 /**
87 * Browse all event templates.
88 *
89 * @return void
90 */
91 public function browse() {
92 //get all event templates.
93 $allEventTemplates = array();
94
95 $eventTemplate = new CRM_Event_DAO_Event();
96
97 $eventTypes = CRM_Event_PseudoConstant::eventType();
98 $participantRoles = CRM_Event_PseudoConstant::participantRole();
99 $participantListings = CRM_Event_PseudoConstant::participantListing();
100
101 //find all event templates.
102 $eventTemplate->is_template = TRUE;
103 $eventTemplate->find();
104 while ($eventTemplate->fetch()) {
105 CRM_Core_DAO::storeValues($eventTemplate, $allEventTemplates[$eventTemplate->id]);
106
107 //get listing types.
108 if ($eventTemplate->participant_listing_id) {
109 $allEventTemplates[$eventTemplate->id]['participant_listing'] = $participantListings[$eventTemplate->participant_listing_id];
110 }
111
112 //get participant role
113 if ($eventTemplate->default_role_id) {
114 $allEventTemplates[$eventTemplate->id]['participant_role'] = $participantRoles[$eventTemplate->default_role_id];
115 }
116
117 //get event type.
118 if (isset($eventTypes[$eventTemplate->event_type_id])) {
119 $allEventTemplates[$eventTemplate->id]['event_type'] = $eventTypes[$eventTemplate->event_type_id];
120 }
121
122 //form all action links
123 $action = array_sum(array_keys($this->links()));
124
125 //add action links.
126 $allEventTemplates[$eventTemplate->id]['action'] = CRM_Core_Action::formLink(self::links(), $action,
127 array('id' => $eventTemplate->id),
128 ts('more'),
129 FALSE,
130 'eventTemplate.manage.action',
131 'Event',
132 $eventTemplate->id
133 );
134 }
135 $this->assign('rows', $allEventTemplates);
136
137 $session = CRM_Core_Session::singleton();
138 $session->pushUserContext(CRM_Utils_System::url(CRM_Utils_System::currentPath(),
139 'reset=1&action=browse'
140 ));
141 }
142
143 /**
144 * Get name of edit form.
145 *
146 * @return string
147 * Classname of edit form.
148 */
149 public function editForm() {
150 return 'CRM_Admin_Form_EventTemplate';
151 }
152
153 /**
154 * Get edit form name.
155 *
156 * @return string
157 * name of this page.
158 */
159 public function editName() {
160 return 'Event Templates';
161 }
162
163 /**
164 * Get user context.
165 *
166 * @param null $mode
167 *
168 * @return string
169 * user context.
170 */
171 public function userContext($mode = NULL) {
172 return 'civicrm/admin/eventTemplate';
173 }
174
175 }