function show_header($user) {
common_element('link', array('rel' => 'alternate',
- 'href' => common_local_url('rss10', array('nickname' =>
+ 'href' => common_local_url('userrss', array('nickname' =>
$user->nickname)),
'type' => 'application/rss+xml',
'title' => _t('Notice feed for ') . $user->nickname));
+ # for remote subscriptions etc.
+ common_element('meta', array('http-equiv' => 'X-XRDS-Location',
+ 'content' => common_local_url('xrds', array('nickname' =>
+ $user->nickname))));
}
function no_such_user() {
$this->show_last_notice($profile);
+ $cur = common_current_user();
+
if ($cur && $cur->id != $profile->id) {
if ($cur->isSubscribed($profile)) {
$this->show_unsubscribe_form($profile);
'name' => 'subscribeto',
'type' => 'hidden',
'value' => $profile->nickname));
- common_element('input', array('type' => 'submit', 'value' => _t('Subscribe')));
+ common_element('input', array('type' => 'submit',
+ 'class' => 'button',
+ 'value' => _t('Subscribe')));
common_element_end('form');
}
'name' => 'unsubscribeto',
'type' => 'hidden',
'value' => $profile->nickname));
- common_element('input', array('type' => 'submit'), _t('Unsubscribe'));
+ common_element('input', array('type' => 'submit',
+ 'class' => 'button',
+ 'value' => _t('Unsubscribe')));
common_element_end('form');
}
global $config;
# XXX: add a limit
- $subs = $profile->getLink('id', 'subscription', 'subscriber');
+ $subs = DB_DataObject::factory('subscription');
+ $subs->subscriber = $profile->id;
+
+ # We ask for an extra one to know if we need to do another page
+
+ $subs->limit(0, SUBSCRIPTIONS);
+
+ $subs_count = $subs->find();
common_element_start('div', 'subscriptions');
common_element('h2', 'subscriptions', _t('Subscriptions'));
- $cnt = 0;
-
- if ($subs) {
- while ($subs->fetch()) {
- $cnt++;
- if ($cnt % SUBSCRIPTIONS_PER_ROW == 1) {
- common_element_start('div', 'row');
- }
-
- common_element_start('a', array('title' => ($subs->fullname) ?
- $subs->fullname :
- $subs->nickname,
- 'href' => $subs->profileurl,
- 'class' => 'subscription'));
- $avatar = $subs->getAvatar(AVATAR_MINI_SIZE);
- common_element('img', array('src' => (($avatar) ? $avatar->url : common_default_avatar(AVATAR_MINI_SIZE),
- 'width' => AVATAR_MINI_SIZE,
- 'height' => AVATAR_MINI_SIZE,
- 'class' => 'avatar mini',
- 'alt' => ($subs->fullname) ?
- $subs->fullname :
- $subs->nickname));
- common_element_end('a');
-
- if ($cnt % SUBSCRIPTIONS_PER_ROW == 0) {
- common_element_end('div');
- }
-
- if ($cnt == SUBSCRIPTIONS) {
- break;
- }
+ $idx = 0;
+
+ while ($subs->fetch()) {
+ $idx++;
+ if ($idx % SUBSCRIPTIONS_PER_ROW == 1) {
+ common_element_start('div', 'row');
+ }
+
+ $other = Profile::staticGet($subs->subscribed);
+
+ common_element_start('a', array('title' => ($other->fullname) ?
+ $other->fullname :
+ $other->nickname,
+ 'href' => $other->profileurl,
+ 'class' => 'subscription'));
+ $avatar = $other->getAvatar(AVATAR_MINI_SIZE);
+ common_element('img', array('src' => (($avatar) ? $avatar->url : common_default_avatar(AVATAR_MINI_SIZE)),
+ 'width' => AVATAR_MINI_SIZE,
+ 'height' => AVATAR_MINI_SIZE,
+ 'class' => 'avatar mini',
+ 'alt' => ($other->fullname) ?
+ $other->fullname :
+ $other->nickname));
+ common_element_end('a');
+
+ if ($idx % SUBSCRIPTIONS_PER_ROW == 0) {
+ common_element_end('div');
+ }
+
+ if ($idx == SUBSCRIPTIONS) {
+ break;
}
}
+ # close any unclosed row
+ if ($idx % SUBSCRIPTIONS_PER_ROW != 0) {
+ common_element_end('div');
+ }
+
common_element('a', array('href' => common_local_url('subscriptions',
array('nickname' => $profile->nickname)),
'class' => 'moresubscriptions'),
// XXX: WORM cache this
$subs = DB_DataObject::factory('subscription');
$subs->subscriber = $profile->id;
- $subs_count = $subs->count();
-
- if (!$subs_count) {
- $subs_count = 0;
- }
+ $subs_count = (int) $subs->count();
$subbed = DB_DataObject::factory('subscription');
$subbed->subscribed = $profile->id;
- $subbed_count = $subbed->count();
-
- if (!$subbed_count) {
- $subbed_count = 0;
- }
+ $subbed_count = (int) $subbed->count();
$notices = DB_DataObject::factory('notice');
$notices->profile_id = $profile->id;
- $notice_count = $notices->count();
-
- if (!$notice_count) {
- $notice_count = 0;
- }
+ $notice_count = (int) $notices->count();
common_element_start('div', 'statistics');
common_element('h2', 'statistics', _t('Statistics'));
$notice->orderBy('created DESC');
- $page = $this->arg('page') || 1;
+ $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
- $notice->limit((($page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE);
+ $notice->limit((($page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1);
- $notice->find();
+ $cnt = $notice->find();
common_element_start('div', 'notices width66 floatLeft');
common_element_start('ul', 'bigLinks');
-
- while ($notice->fetch()) {
- $this->show_notice($notice);
+
+ for ($i = 0; $i < min($cnt, NOTICES_PER_PAGE); $i++) {
+ if ($notice->fetch()) {
+ $this->show_notice($notice);
+ } else {
+ // shouldn't happen!
+ break;
+ }
}
common_element_end('ul');
+
+ if ($page > 1) {
+ common_element_start('span', 'floatLeft width25');
+ common_element('a', array('href' => common_local_url('showstream',
+ array('nickname' => $profile->nickname,
+ 'page' => $page-1)),
+ 'class' => 'newer'),
+ _t('Newer'));
+ common_element_end('span');
+ }
+
+ if ($cnt > NOTICES_PER_PAGE) {
+ common_element_start('span', 'floatRight width25');
+ common_element('a', array('href' => common_local_url('showstream',
+ array('nickname' => $profile->nickname,
+ 'page' => $page+1)),
+ 'class' => 'older'),
+ _t('Older'));
+ common_element_end('span');
+ }
# XXX: show a link for the next page
common_element_end('div');