3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
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 +--------------------------------------------------------------------+
29 * This class introduces component to the system and provides all the
30 * information about it. It needs to extend CRM_Core_Component_Info
34 * @copyright CiviCRM LLC (c) 2004-2014
38 class CRM_Member_Info
extends CRM_Core_Component_Info
{
43 protected $keyword = 'member';
47 * Provides base information about the component.
48 * Needs to be implemented in component's information
52 * collection of required component settings
57 public function getInfo() {
59 'name' => 'CiviMember',
60 'translatedName' => ts('CiviMember'),
61 'title' => 'CiviCRM Membership Engine',
63 'showActivitiesInCore' => 1,
70 * Provides permissions that are used by component.
71 * Needs to be implemented in component's information
74 * NOTE: if using conditionally permission return,
75 * implementation of $getAllUnconditionally is required.
77 * @param bool $getAllUnconditionally
80 * collection of permissions, null if none
83 * @param bool $getAllUnconditionally
87 public function getPermissions($getAllUnconditionally = FALSE) {
91 'delete in CiviMember',
97 * Provides information about user dashboard element
98 * offered by this component.
101 * collection of required dashboard settings,
102 * null if no element offered
107 public function getUserDashboardElement() {
109 'name' => ts('Memberships'),
110 'title' => ts('Your Membership(s)'),
111 // this is CiviContribute specific permission, since
112 // there is no permission that could be checked for
114 'perm' => array('make online contributions'),
121 * Provides information about user dashboard element
122 * offered by this component.
125 * collection of required dashboard settings,
126 * null if no element offered
131 public function registerTab() {
133 'title' => ts('Memberships'),
134 'url' => 'membership',
141 * Provides information about advanced search pane
142 * offered by this component.
145 * collection of required pane settings,
146 * null if no element offered
151 public function registerAdvancedSearchPane() {
153 'title' => ts('Memberships'),
160 * Provides potential activity types that this
161 * component might want to register in activity history.
162 * Needs to be implemented in component's information
166 * collection of activity types
171 public function getActivityTypes() {
176 * add shortcut to Create New
180 public function creatNewShortcut(&$shortCuts, $newCredit) {
181 if (CRM_Core_Permission
::check('access CiviMember') &&
182 CRM_Core_Permission
::check('edit memberships')
185 'path' => 'civicrm/member/add',
186 'query' => "reset=1&action=add&context=standalone",
187 'ref' => 'new-membership',
188 'title' => ts('Membership'),
191 $title = ts('Membership') . '<br /> (' . ts('credit card') . ')';
192 $shortCut[0]['shortCuts'][] = array(
193 'path' => 'civicrm/member/add',
194 'query' => "reset=1&action=add&context=standalone&mode=live",
195 'ref' => 'new-membership-cc',
199 $shortCuts = array_merge($shortCuts, $shortCut);