3 * StatusNet, the distributed open-source microblogging tool
5 * Tabset for a particular group
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Evan Prodromou <evan@status.net>
25 * @author Sarven Capadisli <csarven@status.net>
26 * @copyright 2008 StatusNet, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
28 * @link http://status.net/
31 if (!defined('STATUSNET') && !defined('LACONICA')) {
35 require_once INSTALLDIR.'/lib/widget.php';
40 * Shows a group of tabs for a particular user group
44 * @author Evan Prodromou <evan@status.net>
45 * @author Sarven Capadisli <csarven@status.net>
46 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
47 * @link http://status.net/
52 class GroupNav extends Menu
59 * @param Action $action current action, used for output
62 function __construct($action=null, $group=null)
64 parent::__construct($action);
65 $this->group = $group;
76 $action_name = $this->action->trimmed('action');
77 $nickname = $this->group->nickname;
79 $this->out->elementStart('ul', array('class' => 'nav'));
80 if (Event::handle('StartGroupGroupNav', array($this))) {
81 $this->out->menuItem(common_local_url('showgroup', array('nickname' =>
83 // TRANS: Menu item in the group navigation page.
85 // TRANS: Tooltip for menu item in the group navigation page.
86 // TRANS: %s is the nickname of the group.
87 sprintf(_m('TOOLTIP','%s group'), $nickname),
88 $action_name == 'showgroup',
90 $this->out->menuItem(common_local_url('groupmembers', array('nickname' =>
92 // TRANS: Menu item in the group navigation page.
94 // TRANS: Tooltip for menu item in the group navigation page.
95 // TRANS: %s is the nickname of the group.
96 sprintf(_m('TOOLTIP','%s group members'), $nickname),
97 $action_name == 'groupmembers',
100 $cur = common_current_user();
102 if ($cur && $cur->isAdmin($this->group)) {
103 $this->out->menuItem(common_local_url('blockedfromgroup', array('nickname' =>
105 // TRANS: Menu item in the group navigation page. Only shown for group administrators.
106 _m('MENU','Blocked'),
107 // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
108 // TRANS: %s is the nickname of the group.
109 sprintf(_m('TOOLTIP','%s blocked users'), $nickname),
110 $action_name == 'blockedfromgroup',
111 'nav_group_blocked');
112 $this->out->menuItem(common_local_url('editgroup', array('nickname' =>
114 // TRANS: Menu item in the group navigation page. Only shown for group administrators.
116 // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
117 // TRANS: %s is the nickname of the group.
118 sprintf(_m('TOOLTIP','Edit %s group properties'), $nickname),
119 $action_name == 'editgroup',
121 $this->out->menuItem(common_local_url('grouplogo', array('nickname' =>
123 // TRANS: Menu item in the group navigation page. Only shown for group administrators.
125 // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
126 // TRANS: %s is the nickname of the group.
127 sprintf(_m('TOOLTIP','Add or edit %s logo'), $nickname),
128 $action_name == 'grouplogo',
130 $this->out->menuItem(common_local_url('groupdesignsettings', array('nickname' =>
132 // TRANS: Menu item in the group navigation page. Only shown for group administrators.
134 // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
135 // TRANS: %s is the nickname of the group.
136 sprintf(_m('TOOLTIP','Add or edit %s design'), $nickname),
137 $action_name == 'groupdesignsettings',
140 Event::handle('EndGroupGroupNav', array($this));
142 $this->out->elementEnd('ul');