hide buttons for repeat, delete system activities

This commit is contained in:
Evan Prodromou 2011-08-24 17:17:03 -04:00
parent eef89c6712
commit 3d831ebcfb
6 changed files with 106 additions and 83 deletions

View File

@ -67,6 +67,7 @@ class ActivityPlugin extends Plugin
case 'LeaveListItem': case 'LeaveListItem':
case 'FollowListItem': case 'FollowListItem':
case 'UnfollowListItem': case 'UnfollowListItem':
case 'SystemListItem':
include_once $dir . '/'.strtolower($cls).'.php'; include_once $dir . '/'.strtolower($cls).'.php';
return false; return false;
default: default:

View File

@ -45,34 +45,7 @@ if (!defined('STATUSNET')) {
* @link http://status.net/ * @link http://status.net/
*/ */
class FollowListItem extends NoticeListItemAdapter class FollowListItem extends SystemListItem
{ {
/**
* Show the join activity
*
* @return void
*/
function showNotice()
{
$out = $this->nli->out;
$out->elementStart('div', 'entry-title');
$this->showContent();
$out->elementEnd('div');
}
function showContent()
{
$notice = $this->nli->notice;
$out = $this->nli->out;
// FIXME: get the actual data on the leave
$out->elementStart('div', 'follow-activity');
$out->raw($notice->rendered);
$out->elementEnd('div');
}
} }

View File

@ -3,7 +3,7 @@
* StatusNet - the distributed open-source microblogging tool * StatusNet - the distributed open-source microblogging tool
* Copyright (C) 2011, StatusNet, Inc. * Copyright (C) 2011, StatusNet, Inc.
* *
* Title of module * List item for when you join a group
* *
* PHP version 5 * PHP version 5
* *
@ -45,22 +45,8 @@ if (!defined('STATUSNET')) {
* @link http://status.net/ * @link http://status.net/
*/ */
class JoinListItem extends NoticeListItemAdapter class JoinListItem extends SystemListItem
{ {
/**
* Show the join activity
*
* @return void
*/
function showNotice()
{
$out = $this->nli->out;
$out->elementStart('div', 'entry-title');
$this->showContent();
$out->elementEnd('div');
}
function showContent() function showContent()
{ {
$notice = $this->nli->notice; $notice = $this->nli->notice;
@ -68,9 +54,8 @@ class JoinListItem extends NoticeListItemAdapter
$mem = Group_member::staticGet('uri', $notice->uri); $mem = Group_member::staticGet('uri', $notice->uri);
$out->elementStart('div', 'join-activity');
if (!empty($mem)) { if (!empty($mem)) {
$out->elementStart('div', 'join-activity');
$profile = $mem->getMember(); $profile = $mem->getMember();
$group = $mem->getGroup(); $group = $mem->getGroup();
$out->raw(sprintf(_m('<em><a href="%s">%s</a> joined the group <a href="%s">%s</a></em>.'), $out->raw(sprintf(_m('<em><a href="%s">%s</a> joined the group <a href="%s">%s</a></em>.'),
@ -78,11 +63,11 @@ class JoinListItem extends NoticeListItemAdapter
$profile->getBestName(), $profile->getBestName(),
$group->homeUrl(), $group->homeUrl(),
$group->getBestName())); $group->getBestName()));
} else {
$out->raw($entry->summary);
}
$out->elementEnd('div'); $out->elementEnd('div');
} else {
parent::showContent();
}
} }
} }

View File

@ -3,7 +3,7 @@
* StatusNet - the distributed open-source microblogging tool * StatusNet - the distributed open-source microblogging tool
* Copyright (C) 2011, StatusNet, Inc. * Copyright (C) 2011, StatusNet, Inc.
* *
* Title of module * List item for when you leave a group
* *
* PHP version 5 * PHP version 5
* *
@ -35,7 +35,7 @@ if (!defined('STATUSNET')) {
} }
/** /**
* NoticeListItemAdapter for join activities * NoticeListItemAdapter for leave activities
* *
* @category General * @category General
* @package StatusNet * @package StatusNet
@ -45,34 +45,7 @@ if (!defined('STATUSNET')) {
* @link http://status.net/ * @link http://status.net/
*/ */
class LeaveListItem extends NoticeListItemAdapter class LeaveListItem extends SystemListItem
{ {
/**
* Show the join activity
*
* @return void
*/
function showNotice()
{
$out = $this->nli->out;
$out->elementStart('div', 'entry-title');
$this->showContent();
$out->elementEnd('div');
}
function showContent()
{
$notice = $this->nli->notice;
$out = $this->nli->out;
// FIXME: get the actual data on the leave
$out->elementStart('div', 'leave-activity');
$out->raw($notice->rendered);
$out->elementEnd('div');
}
} }

View File

@ -0,0 +1,91 @@
<?php
/**
* StatusNet - the distributed open-source microblogging tool
* Copyright (C) 2011, StatusNet, Inc.
*
* Superclass for system event items
*
* PHP version 5
*
* This program 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.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*
* @category Activity
* @package StatusNet
* @author Evan Prodromou <evan@status.net>
* @copyright 2011 StatusNet, Inc.
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
* @link http://status.net/
*/
if (!defined('STATUSNET')) {
// This check helps protect against security problems;
// your code file can't be executed directly from the web.
exit(1);
}
/**
* NoticeListItemAdapter for system activities
*
* @category General
* @package StatusNet
* @author Evan Prodromou <evan@status.net>
* @copyright 2011 StatusNet, Inc.
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
* @link http://status.net/
*/
abstract class SystemListItem extends NoticeListItemAdapter
{
/**
* Show the activity
*
* @return void
*/
function showNotice()
{
$out = $this->nli->out;
$out->elementStart('div', 'entry-title');
$this->showContent();
$out->elementEnd('div');
}
function showContent()
{
$notice = $this->nli->notice;
$out = $this->nli->out;
// FIXME: get the actual data on the leave
$out->elementStart('div', 'system-activity');
$out->raw($notice->rendered);
$out->elementEnd('div');
}
function showNoticeOptions()
{
if (Event::handle('StartShowNoticeOptions', array($this))) {
$user = common_current_user();
if (!empty($user)) {
$this->nli->out->elementStart('div', 'notice-options');
$this->showFaveForm();
$this->showReplyLink();
$this->nli->out->elementEnd('div');
}
Event::handle('EndShowNoticeOptions', array($this));
}
}
}

View File

@ -3,7 +3,7 @@
* StatusNet - the distributed open-source microblogging tool * StatusNet - the distributed open-source microblogging tool
* Copyright (C) 2011, StatusNet, Inc. * Copyright (C) 2011, StatusNet, Inc.
* *
* Title of module * Unfollow list item
* *
* PHP version 5 * PHP version 5
* *
@ -20,7 +20,7 @@
* You should have received a copy of the GNU Affero General Public License * You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
* *
* @category Cache * @category Activity
* @package StatusNet * @package StatusNet
* @author Evan Prodromou <evan@status.net> * @author Evan Prodromou <evan@status.net>
* @copyright 2011 StatusNet, Inc. * @copyright 2011 StatusNet, Inc.
@ -45,7 +45,7 @@ if (!defined('STATUSNET')) {
* @link http://status.net/ * @link http://status.net/
*/ */
class UnfollowListItem extends NoticeListItemAdapter class UnfollowListItem extends SystemListItem
{ {
/** /**
* Show the join activity * Show the join activity