gnu-social/actions/groupmembers.php

99 lines
2.8 KiB
PHP
Raw Normal View History

2009-01-21 14:52:21 +00:00
<?php
// This file is part of GNU social - https://www.gnu.org/software/social
//
// GNU social is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// GNU social is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
2009-01-21 14:52:21 +00:00
/**
* List of group members
*
* @category Group
* @package GNUsocial
* @author Evan Prodromou <evan@status.net>
* @copyright 2008-2009 StatusNet, Inc.
* @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
2009-01-21 14:52:21 +00:00
*/
defined('GNUSOCIAL') || die();
2009-01-21 14:52:21 +00:00
/**
* List of group members
*
* @category Group
* @package GNUsocial
* @author Evan Prodromou <evan@status.net>
* @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
2009-01-21 14:52:21 +00:00
*/
class GroupmembersAction extends GroupAction
2009-01-21 14:52:21 +00:00
{
public $page = null;
2009-01-21 14:52:21 +00:00
public function isReadOnly($args)
2009-01-21 14:52:21 +00:00
{
return true;
}
public function title()
2009-01-21 14:52:21 +00:00
{
if ($this->page == 1) {
2010-09-12 16:27:38 +01:00
// TRANS: Title of the page showing group members.
// TRANS: %s is the name of the group.
return sprintf(
_('%s group members'),
$this->group->nickname
);
2009-01-21 14:52:21 +00:00
} else {
2010-09-12 16:27:38 +01:00
// TRANS: Title of the page showing group members.
// TRANS: %1$s is the name of the group, %2$d is the page number of the members list.
return sprintf(
_('%1$s group members, page %2$d'),
$this->group->nickname,
$this->page
);
2009-01-21 14:52:21 +00:00
}
}
public function showPageNotice()
2009-01-21 14:52:21 +00:00
{
$this->element(
'p',
'instructions',
// TRANS: Page notice for group members page.
_('A list of the users in this group.')
);
2009-01-21 14:52:21 +00:00
}
public function showContent()
2009-01-21 14:52:21 +00:00
{
$offset = ($this->page-1) * PROFILES_PER_PAGE;
$limit = PROFILES_PER_PAGE + 1;
2009-01-21 14:52:21 +00:00
2009-01-29 13:37:40 +00:00
$cnt = 0;
2009-01-21 14:52:21 +00:00
$members = $this->group->getMembers($offset, $limit);
if ($members) {
$member_list = new GroupMemberList($members, $this->group, $this);
2009-01-29 13:37:40 +00:00
$cnt = $member_list->show();
2009-01-21 14:52:21 +00:00
}
$this->pagination(
$this->page > 1,
$cnt > PROFILES_PER_PAGE,
$this->page,
'groupmembers',
['nickname' => $this->group->nickname]
);
2009-01-21 14:52:21 +00:00
}
}