summaryrefslogtreecommitdiff
path: root/actions/showstream.php
diff options
context:
space:
mode:
Diffstat (limited to 'actions/showstream.php')
-rw-r--r--actions/showstream.php600
1 files changed, 325 insertions, 275 deletions
diff --git a/actions/showstream.php b/actions/showstream.php
index e4e5d96d1..3882af845 100644
--- a/actions/showstream.php
+++ b/actions/showstream.php
@@ -1,9 +1,12 @@
<?php
-/*
- * Laconica - a distributed open-source microblogging tool
- * Copyright (C) 2008, Controlez-Vous, Inc.
+/**
+ * Laconica, the distributed open-source microblogging tool
*
- * This program is free software: you can redistribute it and/or modify
+ * User profile page
+ *
+ * PHP version 5
+ *
+ * LICENCE: 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.
@@ -15,27 +18,65 @@
*
* 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 Personal
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @author Sarven Capadisli <csarven@controlyourself.ca>
+ * @copyright 2008-2009 Control Yourself, Inc.
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://laconi.ca/
*/
-if (!defined('LACONICA')) { exit(1); }
+if (!defined('LACONICA')) {
+ exit(1);
+}
-require_once(INSTALLDIR.'/lib/stream.php');
+require_once INSTALLDIR.'/lib/personalgroupnav.php';
+require_once INSTALLDIR.'/lib/noticelist.php';
+require_once INSTALLDIR.'/lib/feedlist.php';
-define('SUBSCRIPTIONS_PER_ROW', 4);
-define('SUBSCRIPTIONS', 80);
+/**
+ * User profile page
+ *
+ * When I created this page, "show stream" seemed like the best name for it.
+ * Now, it seems like a really bad name.
+ *
+ * It shows a stream of the user's posts, plus lots of profile info, links
+ * to subscriptions and stuff, etc.
+ *
+ * @category Personal
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://laconi.ca/
+ */
-class ShowstreamAction extends StreamAction
+class ShowstreamAction extends Action
{
+ var $user = null;
+ var $page = null;
+ var $profile = null;
- function handle($args)
+ function title()
{
+ if ($this->page == 1) {
+ return $this->user->nickname;
+ } else {
+ return sprintf(_("%s, page %d"),
+ $this->user->nickname,
+ $this->page);
+ }
+ }
- parent::handle($args);
+ function prepare($args)
+ {
+ parent::prepare($args);
$nickname_arg = $this->arg('nickname');
$nickname = common_canonical_nickname($nickname_arg);
- # Permanent redirect on non-canonical nickname
+ // Permanent redirect on non-canonical nickname
if ($nickname_arg != $nickname) {
$args = array('nickname' => $nickname);
@@ -43,263 +84,314 @@ class ShowstreamAction extends StreamAction
$args['page'] = $this->arg['page'];
}
common_redirect(common_local_url('showstream', $args), 301);
- return;
+ return false;
}
- $user = User::staticGet('nickname', $nickname);
+ $this->user = User::staticGet('nickname', $nickname);
- if (!$user) {
- $this->no_such_user();
- return;
+ if (!$this->user) {
+ $this->clientError(_('No such user.'), 404);
+ return false;
}
- $profile = $user->getProfile();
+ $this->profile = $this->user->getProfile();
- if (!$profile) {
- common_server_error(_('User has no profile.'));
- return;
+ if (!$this->profile) {
+ $this->serverError(_('User has no profile.'));
+ return false;
}
- # Looks like we're good; start output
+ $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
- # For YADIS discovery, we also have a <meta> tag
+ return true;
+ }
- header('X-XRDS-Location: '. common_local_url('xrds', array('nickname' =>
- $user->nickname)));
+ function handle($args)
+ {
- common_show_header($profile->nickname,
- array($this, 'show_header'), $user,
- array($this, 'show_top'));
+ // Looks like we're good; start output
- $this->show_profile($profile);
+ // For YADIS discovery, we also have a <meta> tag
- $this->show_notices($user);
+ header('X-XRDS-Location: '. common_local_url('xrds', array('nickname' =>
+ $this->user->nickname)));
- common_show_footer();
+ $this->showPage();
}
- function show_top($user)
+ function showContent()
{
- $cur = common_current_user();
+ $this->showProfile();
+ $this->showNotices();
+ }
- if ($cur && $cur->id == $user->id) {
- common_notice_form('showstream');
- }
+ function showLocalNav()
+ {
+ $nav = new PersonalGroupNav($this);
+ $nav->show();
+ }
- $this->views_menu();
-
- $this->show_feeds_list(array(0=>array('href'=>common_local_url('userrss', array('nickname' => $user->nickname)),
- 'type' => 'rss',
- 'version' => 'RSS 1.0',
- 'item' => 'notices'),
- 1=>array('href'=>common_local_url('usertimeline', array('nickname' => $user->nickname)),
- 'type' => 'atom',
- 'version' => 'Atom 1.0',
- 'item' => 'usertimeline'),
-
- 2=>array('href'=>common_local_url('foaf',array('nickname' => $user->nickname)),
- 'type' => 'rdf',
- 'version' => 'FOAF',
- 'item' => 'foaf')));
+ function showPageTitle()
+ {
+ $this->element('h1', NULL, $this->profile->nickname._("'s profile"));
}
- function show_header($user)
+ function showPageNoticeBlock()
{
- # Feeds
- common_element('link', array('rel' => 'alternate',
+ return;
+ }
+
+ function showExportData()
+ {
+ $fl = new FeedList($this);
+ $fl->show(array(0=>array('href'=>common_local_url('userrss',
+ array('nickname' => $this->user->nickname)),
+ 'type' => 'rss',
+ 'version' => 'RSS 1.0',
+ 'item' => 'notices'),
+ 1=>array('href'=>common_local_url('usertimeline',
+ array('nickname' => $this->user->nickname)),
+ 'type' => 'atom',
+ 'version' => 'Atom 1.0',
+ 'item' => 'usertimeline'),
+ 2=>array('href'=>common_local_url('foaf',
+ array('nickname' => $this->user->nickname)),
+ 'type' => 'rdf',
+ 'version' => 'FOAF',
+ 'item' => 'foaf')));
+ }
+
+ function showFeeds()
+ {
+ // Feeds
+ $this->element('link', array('rel' => 'alternate',
'href' => common_local_url('api',
array('apiaction' => 'statuses',
'method' => 'user_timeline.rss',
- 'argument' => $user->nickname)),
+ 'argument' => $this->user->nickname)),
'type' => 'application/rss+xml',
- 'title' => sprintf(_('Notice feed for %s'), $user->nickname)));
- common_element('link', array('rel' => 'alternate feed',
+ 'title' => sprintf(_('Notice feed for %s'), $this->user->nickname)));
+ $this->element('link', array('rel' => 'alternate feed',
'href' => common_local_url('api',
array('apiaction' => 'statuses',
'method' => 'user_timeline.atom',
- 'argument' => $user->nickname)),
+ 'argument' => $this->user->nickname)),
'type' => 'application/atom+xml',
- 'title' => sprintf(_('Notice feed for %s'), $user->nickname)));
- common_element('link', array('rel' => 'alternate',
+ 'title' => sprintf(_('Notice feed for %s'), $this->user->nickname)));
+ $this->element('link', array('rel' => 'alternate',
'href' => common_local_url('userrss', array('nickname' =>
- $user->nickname)),
+ $this->user->nickname)),
'type' => 'application/rdf+xml',
- 'title' => sprintf(_('Notice feed for %s'), $user->nickname)));
- # FOAF
- common_element('link', array('rel' => 'meta',
+ 'title' => sprintf(_('Notice feed for %s'), $this->user->nickname)));
+ }
+
+ function extraHead()
+ {
+ // FOAF
+ $this->element('link', array('rel' => 'meta',
'href' => common_local_url('foaf', array('nickname' =>
- $user->nickname)),
+ $this->user->nickname)),
'type' => 'application/rdf+xml',
'title' => 'FOAF'));
- # for remote subscriptions etc.
- common_element('meta', array('http-equiv' => 'X-XRDS-Location',
+ // for remote subscriptions etc.
+ $this->element('meta', array('http-equiv' => 'X-XRDS-Location',
'content' => common_local_url('xrds', array('nickname' =>
- $user->nickname))));
- $profile = $user->getProfile();
- if ($profile->bio) {
- common_element('meta', array('name' => 'description',
- 'content' => $profile->bio));
+ $this->user->nickname))));
+
+ if ($this->profile->bio) {
+ $this->element('meta', array('name' => 'description',
+ 'content' => $this->profile->bio));
}
- if ($user->emailmicroid && $user->email && $profile->profileurl) {
- common_element('meta', array('name' => 'microid',
- 'content' => "mailto+http:sha1:" . sha1(sha1('mailto:' . $user->email) . sha1($profile->profileurl))));
+ if ($this->user->emailmicroid && $this->user->email && $this->profile->profileurl) {
+ $id = new Microid('mailto:'.$this->user->email,
+ $this->selfUrl());
+ $this->element('meta', array('name' => 'microid',
+ 'content' => $id->toString()));
}
- if ($user->jabbermicroid && $user->jabber && $profile->profileurl) {
- common_element('meta', array('name' => 'microid',
- 'content' => "xmpp+http:sha1:" . sha1(sha1('xmpp:' . $user->jabber) . sha1($profile->profileurl))));
+ if ($this->user->jabbermicroid && $this->user->jabber && $this->profile->profileurl) {
+ $id = new Microid('xmpp:'.$this->user->jabber,
+ $this->selfUrl());
+ $this->element('meta', array('name' => 'microid',
+ 'content' => $id->toString()));
}
- # See https://wiki.mozilla.org/Microsummaries
+ // See https://wiki.mozilla.org/Microsummaries
- common_element('link', array('rel' => 'microsummary',
+ $this->element('link', array('rel' => 'microsummary',
'href' => common_local_url('microsummary',
- array('nickname' => $profile->nickname))));
+ array('nickname' => $this->profile->nickname))));
}
- function no_such_user()
+ function showProfile()
{
- $this->client_error(_('No such user.'), 404);
- }
-
- function show_profile($profile)
- {
-
- common_element_start('div', array('id' => 'profile', 'class' => 'vcard'));
-
- $this->show_personal($profile);
-
- $this->show_last_notice($profile);
-
- $cur = common_current_user();
+ $this->elementStart('div', array('id' => 'user_profile', 'class' => 'vcard author'));
+ $this->element('h2', null, _('User profile'));
+
+ $avatar = $this->profile->getAvatar(AVATAR_PROFILE_SIZE);
+ $this->elementStart('dl', 'user_depiction');
+ $this->element('dt', null, _('Photo'));
+ $this->elementStart('dd');
+ $this->element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_PROFILE_SIZE),
+ 'class' => 'photo avatar',
+ 'width' => AVATAR_PROFILE_SIZE,
+ 'height' => AVATAR_PROFILE_SIZE,
+ 'alt' => $this->profile->nickname));
+ $this->elementEnd('dd');
+ $this->elementEnd('dl');
+
+ $this->elementStart('dl', 'user_nickname');
+ $this->element('dt', null, _('Nickname'));
+ $this->elementStart('dd');
+ $hasFN = ($this->profile->fullname) ? 'nickname url uid' : 'fn nickname url uid';
+ $this->element('a', array('href' => $this->profile->profileurl,
+ 'rel' => 'me', 'class' => $hasFN),
+ $this->profile->nickname);
+ $this->elementEnd('dd');
+ $this->elementEnd('dl');
+
+ if ($this->profile->fullname) {
+ $this->elementStart('dl', 'user_fn');
+ $this->element('dt', null, _('Full name'));
+ $this->elementStart('dd');
+ $this->element('span', 'fn', $this->profile->fullname);
+ $this->elementEnd('dd');
+ $this->elementEnd('dl');
+ }
- $this->show_subscriptions($profile);
+ if ($this->profile->location) {
+ $this->elementStart('dl', 'user_location');
+ $this->element('dt', null, _('Location'));
+ $this->element('dd', 'location', $this->profile->location);
+ $this->elementEnd('dl');
+ }
- common_element_end('div');
- }
+ if ($this->profile->homepage) {
+ $this->elementStart('dl', 'user_url');
+ $this->element('dt', null, _('URL'));
+ $this->elementStart('dd');
+ $this->element('a', array('href' => $this->profile->homepage,
+ 'rel' => 'me', 'class' => 'url'),
+ $this->profile->homepage);
+ $this->elementEnd('dd');
+ $this->elementEnd('dl');
+ }
- function show_personal($profile)
- {
+ if ($this->profile->bio) {
+ $this->elementStart('dl', 'user_note');
+ $this->element('dt', null, _('Note'));
+ $this->element('dd', 'note', $this->profile->bio);
+ $this->elementEnd('dl');
+ }
- $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
- common_element_start('div', array('id' => 'profile_avatar'));
- common_element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_PROFILE_SIZE),
- 'class' => 'avatar profile photo',
- 'width' => AVATAR_PROFILE_SIZE,
- 'height' => AVATAR_PROFILE_SIZE,
- 'alt' => $profile->nickname));
+ $tags = Profile_tag::getTags($this->profile->id, $this->profile->id);
+ if (count($tags) > 0) {
+ $this->elementStart('dl', 'user_tags');
+ $this->element('dt', null, _('Tags'));
+ $this->elementStart('dd');
+ $this->elementStart('ul', 'tags xoxo');
+ foreach ($tags as $tag) {
+ $this->elementStart('li');
+ $this->element('span', 'mark_hash', '#');
+ $this->element('a', array('rel' => 'tag',
+ 'href' => common_local_url('peopletag',
+ array('tag' => $tag))),
+ $tag);
+ $this->elementEnd('li');
+ }
+ $this->elementEnd('ul');
+ $this->elementEnd('dd');
+ $this->elementEnd('dl');
+ }
+ $this->elementEnd('div');
- common_element_start('ul', array('id' => 'profile_actions'));
- common_element_start('li', array('id' => 'profile_subscribe'));
+ $this->elementStart('div', array('id' => 'user_actions'));
+ $this->element('h2', null, _('User actions'));
+ $this->elementStart('ul');
+ $this->elementStart('li', array('id' => 'user_subscribe'));
$cur = common_current_user();
if ($cur) {
- if ($cur->id != $profile->id) {
- if ($cur->isSubscribed($profile)) {
- common_unsubscribe_form($profile);
+ if ($cur->id != $this->profile->id) {
+ if ($cur->isSubscribed($this->profile)) {
+ $sf = new SubscribeForm($this, $this->profile);
+ $sf->show();
} else {
- common_subscribe_form($profile);
+ $usf = new UnsubscribeForm($this, $this->profile);
+ $usf->show();
}
}
} else {
- $this->show_remote_subscribe_link($profile);
+ $this->showRemoteSubscribeLink();
}
- common_element_end('li');
+ $this->elementEnd('li');
- $user = User::staticGet('id', $profile->id);
- common_profile_new_message_nudge($cur, $user, $profile);
+ common_profile_new_message_nudge($cur, $this->user, $this->profile);
- if ($cur && $cur->id != $profile->id) {
- $blocked = $cur->hasBlocked($profile);
- common_element_start('li', array('id' => 'profile_block'));
+ if ($cur && $cur->id != $this->profile->id) {
+ $blocked = $cur->hasBlocked($this->profile);
+ $this->elementStart('li', array('id' => 'user_block'));
if ($blocked) {
- common_unblock_form($profile, array('action' => 'showstream',
- 'nickname' => $profile->nickname));
+ $bf = new BlockForm($this, $this->profile);
+ $bf->show();
} else {
- common_block_form($profile, array('action' => 'showstream',
- 'nickname' => $profile->nickname));
+ $ubf = new UnblockForm($this, $this->profile);
+ $ubf->show();
}
- common_element_end('li');
+ $this->elementEnd('li');
}
-
- common_element_end('ul');
-
- common_element_end('div');
-
- common_element_start('div', array('id' => 'profile_information'));
-
- if ($profile->fullname) {
- common_element('h1', array('class' => 'fn'), $profile->fullname . ' (' . $profile->nickname . ')');
- } else {
- common_element('h1', array('class' => 'fn nickname'), $profile->nickname);
- }
-
- if ($profile->location) {
- common_element('p', 'location', $profile->location);
- }
- if ($profile->bio) {
- common_element('p', 'description note', $profile->bio);
- }
- if ($profile->homepage) {
- common_element_start('p', 'website');
- common_element('a', array('href' => $profile->homepage,
- 'rel' => 'me', 'class' => 'url'),
- $profile->homepage);
- common_element_end('p');
- }
-
- $this->show_statistics($profile);
-
- common_element_end('div');
+ $this->elementEnd('ul');
+ $this->elementEnd('div');
}
- function show_remote_subscribe_link($profile)
+ function showRemoteSubscribeLink()
{
$url = common_local_url('remotesubscribe',
- array('nickname' => $profile->nickname));
- common_element('a', array('href' => $url,
+ array('nickname' => $this->profile->nickname));
+ $this->element('a', array('href' => $url,
'id' => 'remotesubscribe'),
_('Subscribe'));
}
- function show_unsubscribe_form($profile)
+ function showNotices()
{
- common_element_start('form', array('id' => 'unsubscribe', 'method' => 'post',
- 'action' => common_local_url('unsubscribe')));
- common_hidden('token', common_session_token());
- common_element('input', array('id' => 'unsubscribeto',
- 'name' => 'unsubscribeto',
- 'type' => 'hidden',
- 'value' => $profile->nickname));
- common_element('input', array('type' => 'submit',
- 'class' => 'submit',
- 'value' => _('Unsubscribe')));
- common_element_end('form');
+ $notice = $this->user->getNotices(($this->page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1);
+
+ $pnl = new ProfileNoticeList($notice, $this);
+ $cnt = $pnl->show();
+
+ $this->pagination($this->page>1, $cnt>NOTICES_PER_PAGE, $this->page,
+ 'showstream', array('nickname' => $this->user->nickname));
}
- function show_subscriptions($profile)
+ function showSections()
{
- global $config;
+ $this->showStatistics();
+ $this->showSubscriptions();
+ }
- $subs = DB_DataObject::factory('subscription');
- $subs->subscriber = $profile->id;
- $subs->whereAdd('subscribed != ' . $profile->id);
+ function showSubscriptions()
+ {
+ $subs = new Subscription();
+ $subs->subscriber = $this->profile->id;
+ $subs->whereAdd('subscribed != ' . $this->profile->id);
$subs->orderBy('created DESC');
- # We ask for an extra one to know if we need to do another page
+ // We ask for an extra one to know if we need to do another page
$subs->limit(0, SUBSCRIPTIONS + 1);
$subs_count = $subs->find();
- common_element_start('div', array('id' => 'subscriptions'));
+ $this->elementStart('div', array('id' => 'user_subscriptions',
+ 'class' => 'section'));
- common_element('h2', null, _('Subscriptions'));
+ $this->element('h2', null, _('Subscriptions'));
if ($subs_count > 0) {
- common_element_start('ul', array('id' => 'subscriptions_avatars'));
+ $this->elementStart('ul', 'users');
for ($i = 0; $i < min($subs_count, SUBSCRIPTIONS); $i++) {
@@ -315,146 +407,104 @@ class ShowstreamAction extends StreamAction
continue;
}
- common_element_start('li', 'vcard');
- common_element_start('a', array('title' => ($other->fullname) ?
+ $this->elementStart('li', 'vcard');
+ $this->elementStart('a', array('title' => ($other->fullname) ?
$other->fullname :
$other->nickname,
'href' => $other->profileurl,
'rel' => 'contact',
- 'class' => 'subscription fn url'));
+ 'class' => 'url'));
$avatar = $other->getAvatar(AVATAR_MINI_SIZE);
- common_element('img', array('src' => (($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_MINI_SIZE)),
+ $this->element('img', array('src' => (($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_MINI_SIZE)),
'width' => AVATAR_MINI_SIZE,
'height' => AVATAR_MINI_SIZE,
- 'class' => 'avatar mini photo',
+ 'class' => 'avatar photo',
'alt' => ($other->fullname) ?
$other->fullname :
$other->nickname));
- common_element_end('a');
- common_element_end('li');
+ $this->element('span', 'fn nickname', $other->nickname);
+ $this->elementEnd('a');
+ $this->elementEnd('li');
}
- common_element_end('ul');
+ $this->elementEnd('ul');
}
if ($subs_count > SUBSCRIPTIONS) {
- common_element_start('p', array('id' => 'subscriptions_viewall'));
+ $this->elementStart('p');
- common_element('a', array('href' => common_local_url('subscriptions',
- array('nickname' => $profile->nickname)),
- 'class' => 'moresubscriptions'),
+ $this->element('a', array('href' => common_local_url('subscriptions',
+ array('nickname' => $this->profile->nickname)),
+ 'class' => 'mores'),
_('All subscriptions'));
- common_element_end('p');
+ $this->elementEnd('p');
}
- common_element_end('div');
+ $this->elementEnd('div');
}
- function show_statistics($profile)
+ function showStatistics()
{
-
// XXX: WORM cache this
- $subs = DB_DataObject::factory('subscription');
- $subs->subscriber = $profile->id;
+ $subs = new Subscription();
+ $subs->subscriber = $this->profile->id;
$subs_count = (int) $subs->count() - 1;
- $subbed = DB_DataObject::factory('subscription');
- $subbed->subscribed = $profile->id;
+ $subbed = new Subscription();
+ $subbed->subscribed = $this->profile->id;
$subbed_count = (int) $subbed->count() - 1;
- $notices = DB_DataObject::factory('notice');
- $notices->profile_id = $profile->id;
+ $notices = new Notice();
+ $notices->profile_id = $this->profile->id;
$notice_count = (int) $notices->count();
- common_element_start('div', 'statistics');
- common_element('h2', 'statistics', _('Statistics'));
+ $this->elementStart('div', array('id' => 'user_statistics',
+ 'class' => 'section'));
+
+ $this->element('h2', null, _('Statistics'));
- # Other stats...?
- common_element_start('dl', 'statistics');
- common_element('dt', 'membersince', _('Member since'));
- common_element('dd', 'membersince', date('j M Y',
- strtotime($profile->created)));
+ // Other stats...?
+ $this->elementStart('dl', 'user_member-since');
+ $this->element('dt', null, _('Member since'));
+ $this->element('dd', null, date('j M Y',
+ strtotime($this->profile->created)));
+ $this->elementEnd('dl');
- common_element_start('dt', 'subscriptions');
- common_element('a', array('href' => common_local_url('subscriptions',
- array('nickname' => $profile->nickname))),
+ $this->elementStart('dl', 'user_subscriptions');
+ $this->elementStart('dt');
+ $this->element('a', array('href' => common_local_url('subscriptions',
+ array('nickname' => $this->profile->nickname))),
_('Subscriptions'));
- common_element_end('dt');
- common_element('dd', 'subscriptions', (is_int($subs_count)) ? $subs_count : '0');
- common_element_start('dt', 'subscribers');
- common_element('a', array('href' => common_local_url('subscribers',
- array('nickname' => $profile->nickname))),
+ $this->elementEnd('dt');
+ $this->element('dd', null, (is_int($subs_count)) ? $subs_count : '0');
+ $this->elementEnd('dl');
+
+ $this->elementStart('dl', 'user_subscribers');
+ $this->elementStart('dt');
+ $this->element('a', array('href' => common_local_url('subscribers',
+ array('nickname' => $this->profile->nickname))),
_('Subscribers'));
- common_element_end('dt');
- common_element('dd', 'subscribers', (is_int($subbed_count)) ? $subbed_count : '0');
- common_element('dt', 'notices', _('Notices'));
- common_element('dd', 'notices', (is_int($notice_count)) ? $notice_count : '0');
- # XXX: link these to something
- common_element('dt', 'tags', _('Tags'));
- common_element_start('dd', 'tags');
- $tags = Profile_tag::getTags($profile->id, $profile->id);
-
- common_element_start('ul', 'tags xoxo');
- foreach ($tags as $tag) {
- common_element_start('li');
- common_element('a', array('rel' => 'bookmark tag',
- 'href' => common_local_url('peopletag',
- array('tag' => $tag))),
- $tag);
- common_element_end('li');
- }
- common_element_end('ul');
- common_element_end('dd');
+ $this->elementEnd('dt');
+ $this->element('dd', 'subscribers', (is_int($subbed_count)) ? $subbed_count : '0');
+ $this->elementEnd('dl');
- common_element_end('dl');
+ $this->elementStart('dl', 'user_notices');
+ $this->element('dt', null, _('Notices'));
+ $this->element('dd', null, (is_int($notice_count)) ? $notice_count : '0');
+ $this->elementEnd('dl');
- common_element_end('div');
+ $this->elementEnd('div');
}
- function show_notices($user)
- {
-
- $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
-
- $notice = $user->getNotices(($page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1);
-
- $pnl = new ProfileNoticeList($notice);
- $cnt = $pnl->show();
-
- common_pagination($page>1, $cnt>NOTICES_PER_PAGE, $page,
- 'showstream', array('nickname' => $user->nickname));
- }
-
- function show_last_notice($profile)
- {
-
- common_element('h2', null, _('Currently'));
-
- $notice = $profile->getCurrentNotice();
-
- if ($notice) {
- # FIXME: URL, image, video, audio
- common_element_start('p', array('class' => 'notice_current'));
- if ($notice->rendered) {
- common_raw($notice->rendered);
- } else {
- # XXX: may be some uncooked notices in the DB,
- # we cook them right now. This can probably disappear in future
- # versions (>> 0.4.x)
- common_raw(common_render_content($notice->content, $notice));
- }
- common_element_end('p');
- }
- }
}
-# We don't show the author for a profile, since we already know who it is!
+// We don't show the author for a profile, since we already know who it is!
class ProfileNoticeList extends NoticeList
{
function newListItem($notice)
{
- return new ProfileNoticeListItem($notice);
+ return new ProfileNoticeListItem($notice, $this->out);
}
}