3 * StatusNet, the distributed open-source microblogging tool
5 * User groups information
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-2009 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/grouplist.php';
40 * Show the groups a user belongs to
44 * @author Evan Prodromou <evan@status.net>
45 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
46 * @link http://status.net/
49 class UsergroupsAction extends OwnerDesignAction
54 function isReadOnly($args)
61 if ($this->page == 1) {
62 // TRANS: Message is used as a page title. %s is a nick name.
63 return sprintf(_('%s groups'), $this->user->nickname);
65 // TRANS: Message is used as a page title. %1$s is a nick name, %2$d is a page number.
66 return sprintf(_('%1$s groups, page %2$d'),
67 $this->user->nickname,
72 function prepare($args)
74 parent::prepare($args);
76 $nickname_arg = $this->arg('nickname');
77 $nickname = common_canonical_nickname($nickname_arg);
79 // Permanent redirect on non-canonical nickname
81 if ($nickname_arg != $nickname) {
82 $args = array('nickname' => $nickname);
83 if ($this->arg('page') && $this->arg('page') != 1) {
84 $args['page'] = $this->arg['page'];
86 common_redirect(common_local_url('usergroups', $args), 301);
90 $this->user = User::staticGet('nickname', $nickname);
93 $this->clientError(_('No such user.'), 404);
97 $this->profile = $this->user->getProfile();
99 if (!$this->profile) {
100 $this->serverError(_('User has no profile.'));
104 $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
109 function handle($args)
111 parent::handle($args);
115 function showObjectNav()
117 $nav = new SubGroupNav($this, $this->user);
121 function showContent()
123 $this->elementStart('p', array('id' => 'new_group'));
124 $this->element('a', array('href' => common_local_url('newgroup'),
126 _('Create a new group'));
127 $this->elementEnd('p');
129 $this->elementStart('p', array('id' => 'group_search'));
130 $this->element('a', array('href' => common_local_url('groupsearch'),
132 _('Search for more groups'));
133 $this->elementEnd('p');
135 if (Event::handle('StartShowUserGroupsContent', array($this))) {
136 $offset = ($this->page-1) * GROUPS_PER_PAGE;
137 $limit = GROUPS_PER_PAGE + 1;
139 $groups = $this->user->getGroups($offset, $limit);
142 $gl = new GroupList($groups, $this->user, $this);
145 $this->showEmptyListMessage();
149 $this->pagination($this->page > 1, $cnt > GROUPS_PER_PAGE,
150 $this->page, 'usergroups',
151 array('nickname' => $this->user->nickname));
153 Event::handle('EndShowUserGroupsContent', array($this));
157 function showEmptyListMessage()
159 $message = sprintf(_('%s is not a member of any group.'), $this->user->nickname) . ' ';
161 if (common_logged_in()) {
162 $current_user = common_current_user();
163 if ($this->user->id === $current_user->id) {
164 $message .= _('Try [searching for groups](%%action.groupsearch%%) and joining them.');
167 $this->elementStart('div', 'guide');
168 $this->raw(common_markup_to_html($message));
169 $this->elementEnd('div');