* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-class GroupqueueAction extends GroupDesignAction
+class GroupqueueAction extends GroupAction
{
var $page = null;
- function isReadOnly($args)
+ function isReadOnly(array $args=array())
{
return true;
}
- // fixme most of this belongs in a base class, sounds common to most group actions?
- function prepare($args)
+ // @todo FIXME: most of this belongs in a base class, sounds common to most group actions?
+ protected function prepare(array $args=array())
{
parent::prepare($args);
$this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
$args['page'] = $this->page;
}
common_redirect(common_local_url('groupqueue', $args), 301);
- return false;
}
if (!$nickname) {
// TRANS: Client error displayed when trying to view group members without providing a group nickname.
$this->clientError(_('No nickname.'), 404);
- return false;
}
- $local = Local_group::staticGet('nickname', $nickname);
+ $local = Local_group::getKV('nickname', $nickname);
if (!$local) {
// TRANS: Client error displayed when trying to view group members for a non-existing group.
$this->clientError(_('No such group.'), 404);
- return false;
}
- $this->group = User_group::staticGet('id', $local->group_id);
+ $this->group = User_group::getKV('id', $local->group_id);
if (!$this->group) {
// TRANS: Client error displayed when trying to view group members for an object that is not a group.
$this->clientError(_('No such group.'), 404);
- return false;
}
+ $cur = common_current_user();
+ if (!$cur || !$cur->isAdmin($this->group)) {
+ // TRANS: Client error displayed when trying to approve group applicants without being a group administrator.
+ $this->clientError(_('Only the group admin may approve users.'));
+ }
return true;
}
function title()
{
if ($this->page == 1) {
- // TRANS: Title of the page showing pending group members still awaiting approval to join the group.
+ // TRANS: Title of the first page showing pending group members still awaiting approval to join the group.
// TRANS: %s is the name of the group.
return sprintf(_('%s group members awaiting approval'),
$this->group->nickname);
} else {
- // TRANS: Title of the page showing pending group members still awaiting approval to join the group.
+ // TRANS: Title of all but the first page showing pending group members still awaiting approval to join the group.
// 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 awaiting approval, page %2$d'),
$this->group->nickname,
}
}
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
$this->showPage();
}
_('A list of users awaiting approval to join this group.'));
}
- function showObjectNav()
- {
- $nav = new GroupNav($this, $this->group);
- $nav->show();
- }
-
function showContent()
{
$offset = ($this->page-1) * PROFILES_PER_PAGE;
if ($members) {
// @fixme change!
- $member_list = new GroupMemberList($members, $this->group, $this);
+ $member_list = new GroupQueueList($members, $this->group, $this);
$cnt = $member_list->show();
}
$members->free();
$this->pagination($this->page > 1, $cnt > PROFILES_PER_PAGE,
- $this->page, 'groupmembers',
+ $this->page, 'groupqueue',
array('nickname' => $this->group->nickname));
}
}
-class GroupMemberList extends ProfileList
+// @todo FIXME: documentation missing.
+class GroupQueueList extends GroupMemberList
{
- var $group = null;
-
- function __construct($profile, $group, $action)
- {
- parent::__construct($profile, $action);
-
- $this->group = $group;
- }
-
function newListItem($profile)
{
- return new GroupMemberListItem($profile, $this->group, $this->action);
+ return new GroupQueueListItem($profile, $this->group, $this->action);
}
}
-class GroupMemberListItem extends ProfileListItem
+// @todo FIXME: documentation missing.
+class GroupQueueListItem extends GroupMemberListItem
{
- var $group = null;
-
- function __construct($profile, $group, $action)
- {
- parent::__construct($profile, $action);
-
- $this->group = $group;
- }
-
- function showFullName()
- {
- parent::showFullName();
- if ($this->profile->isAdmin($this->group)) {
- $this->out->text(' '); // for separating the classes.
- // TRANS: Indicator in group members list that this user is a group administrator.
- $this->out->element('span', 'role', _('Admin'));
- }
- }
-
function showActions()
{
$this->startActions();
if (Event::handle('StartProfileListItemActionElements', array($this))) {
- $this->showSubscribeButton();
- $this->showMakeAdminForm();
- $this->showGroupBlockForm();
+ $this->showApproveButtons();
Event::handle('EndProfileListItemActionElements', array($this));
}
$this->endActions();
}
- function showMakeAdminForm()
- {
- $user = common_current_user();
-
- if (!empty($user) &&
- $user->id != $this->profile->id &&
- ($user->isAdmin($this->group) || $user->hasRight(Right::MAKEGROUPADMIN)) &&
- !$this->profile->isAdmin($this->group)) {
- $this->out->elementStart('li', 'entity_make_admin');
- $maf = new MakeAdminForm($this->out, $this->profile, $this->group,
- $this->returnToArgs());
- $maf->show();
- $this->out->elementEnd('li');
- }
-
- }
-
- function showGroupBlockForm()
- {
- $user = common_current_user();
-
- if (!empty($user) && $user->id != $this->profile->id && $user->isAdmin($this->group)) {
- $this->out->elementStart('li', 'entity_block');
- $bf = new GroupBlockForm($this->out, $this->profile, $this->group,
- $this->returnToArgs());
- $bf->show();
- $this->out->elementEnd('li');
- }
- }
-
- function linkAttributes()
- {
- $aAttrs = parent::linkAttributes();
-
- if (common_config('nofollow', 'members')) {
- $aAttrs['rel'] .= ' nofollow';
- }
-
- return $aAttrs;
- }
-
- function homepageAttributes()
- {
- $aAttrs = parent::linkAttributes();
-
- if (common_config('nofollow', 'members')) {
- $aAttrs['rel'] = 'nofollow';
- }
-
- return $aAttrs;
- }
-
- /**
- * Fetch necessary return-to arguments for the profile forms
- * to return to this list when they're done.
- *
- * @return array
- */
- protected function returnToArgs()
- {
- $args = array('action' => 'groupmembers',
- 'nickname' => $this->group->nickname);
- $page = $this->out->arg('page');
- if ($page) {
- $args['param-page'] = $page;
- }
- return $args;
- }
-}
-
-/**
- * Form for blocking a user from a group
- *
- * @category Form
- * @package StatusNet
- * @author Evan Prodromou <evan@status.net>
- * @author Sarven Capadisli <csarven@status.net>
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
- * @link http://status.net/
- *
- * @see BlockForm
- */
-class GroupBlockForm extends Form
-{
- /**
- * Profile of user to block
- */
-
- var $profile = null;
-
- /**
- * Group to block the user from
- */
-
- var $group = null;
-
- /**
- * Return-to args
- */
-
- var $args = null;
-
- /**
- * Constructor
- *
- * @param HTMLOutputter $out output channel
- * @param Profile $profile profile of user to block
- * @param User_group $group group to block user from
- * @param array $args return-to args
- */
- function __construct($out=null, $profile=null, $group=null, $args=null)
- {
- parent::__construct($out);
-
- $this->profile = $profile;
- $this->group = $group;
- $this->args = $args;
- }
-
- /**
- * ID of the form
- *
- * @return int ID of the form
- */
- function id()
- {
- // This should be unique for the page.
- return 'block-' . $this->profile->id;
- }
-
- /**
- * class of the form
- *
- * @return string class of the form
- */
- function formClass()
- {
- return 'form_group_block';
- }
-
- /**
- * Action of the form
- *
- * @return string URL of the action
- */
- function action()
- {
- return common_local_url('groupblock');
- }
-
- /**
- * Legend of the Form
- *
- * @return void
- */
- function formLegend()
- {
- // TRANS: Form legend for form to block user from a group.
- $this->out->element('legend', null, _('Block user from group'));
- }
-
- /**
- * Data elements of the form
- *
- * @return void
- */
- function formData()
- {
- $this->out->hidden('blockto-' . $this->profile->id,
- $this->profile->id,
- 'blockto');
- $this->out->hidden('blockgroup-' . $this->group->id,
- $this->group->id,
- 'blockgroup');
- if ($this->args) {
- foreach ($this->args as $k => $v) {
- $this->out->hidden('returnto-' . $k, $v);
- }
- }
- }
-
- /**
- * Action elements
- *
- * @return void
- */
- function formActions()
- {
- $this->out->submit(
- 'submit',
- // TRANS: Button text for the form that will block a user from a group.
- _m('BUTTON','Block'),
- 'submit',
- null,
- // TRANS: Submit button title.
- _m('TOOLTIP', 'Block this user'));
- }
-}
-
-/**
- * Form for making a user an admin for a group
- *
- * @category Form
- * @package StatusNet
- * @author Evan Prodromou <evan@status.net>
- * @author Sarven Capadisli <csarven@status.net>
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
- * @link http://status.net/
- */
-class MakeAdminForm extends Form
-{
- /**
- * Profile of user to block
- */
- var $profile = null;
-
- /**
- * Group to block the user from
- */
- var $group = null;
-
- /**
- * Return-to args
- */
- var $args = null;
-
- /**
- * Constructor
- *
- * @param HTMLOutputter $out output channel
- * @param Profile $profile profile of user to block
- * @param User_group $group group to block user from
- * @param array $args return-to args
- */
- function __construct($out=null, $profile=null, $group=null, $args=null)
- {
- parent::__construct($out);
-
- $this->profile = $profile;
- $this->group = $group;
- $this->args = $args;
- }
-
- /**
- * ID of the form
- *
- * @return int ID of the form
- */
- function id()
- {
- // This should be unique for the page.
- return 'makeadmin-' . $this->profile->id;
- }
-
- /**
- * class of the form
- *
- * @return string class of the form
- */
- function formClass()
- {
- return 'form_make_admin';
- }
-
- /**
- * Action of the form
- *
- * @return string URL of the action
- */
- function action()
- {
- return common_local_url('makeadmin', array('nickname' => $this->group->nickname));
- }
-
- /**
- * Legend of the Form
- *
- * @return void
- */
- function formLegend()
- {
- // TRANS: Form legend for form to make a user a group admin.
- $this->out->element('legend', null, _('Make user an admin of the group'));
- }
-
- /**
- * Data elements of the form
- *
- * @return void
- */
- function formData()
- {
- $this->out->hidden('profileid-' . $this->profile->id,
- $this->profile->id,
- 'profileid');
- $this->out->hidden('groupid-' . $this->group->id,
- $this->group->id,
- 'groupid');
- if ($this->args) {
- foreach ($this->args as $k => $v) {
- $this->out->hidden('returnto-' . $k, $v);
- }
- }
- }
-
- /**
- * Action elements
- *
- * @return void
- */
- function formActions()
+ function showApproveButtons()
{
- $this->out->submit(
- 'submit',
- // TRANS: Button text for the form that will make a user administrator.
- _m('BUTTON','Make Admin'),
- 'submit',
- null,
- // TRANS: Submit button title.
- _m('TOOLTIP','Make this user an admin'));
+ $this->out->elementStart('li', 'entity_approval');
+ $form = new ApproveGroupForm($this->out, $this->group, $this->profile);
+ $form->show();
+ $this->out->elementEnd('li');
}
}