diff options
author | Evan Prodromou <evan@prodromou.name> | 2008-05-17 15:24:47 -0400 |
---|---|---|
committer | Evan Prodromou <evan@prodromou.name> | 2008-05-17 15:24:47 -0400 |
commit | 30089235e0c6e7008217f54cc4b65a686c4e0600 (patch) | |
tree | f01c485f64ca80d0e8bd0c5edb6da5bebe56d450 | |
parent | 726e8fdaf70402e5f658af38b13620972af8ebdf (diff) |
handle empty subscription list
darcs-hash:20080517192447-84dde-f8dc1f4befde5d7624887b13eb7f5730f693c72c.gz
-rw-r--r-- | actions/showstream.php | 115 |
1 files changed, 59 insertions, 56 deletions
diff --git a/actions/showstream.php b/actions/showstream.php index bc16b4d51..03e8de29c 100644 --- a/actions/showstream.php +++ b/actions/showstream.php @@ -1,18 +1,18 @@ <?php -/* +/* * Laconica - a distributed open-source microblogging tool * Copyright (C) 2008, Controlez-Vous, Inc. - * + * * 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/>. */ @@ -27,7 +27,7 @@ define('SUBSCRIPTIONS', 80); class ShowstreamAction extends StreamAction { function handle($args) { - + parent::handle($args); $nickname = common_canonical_nickname($this->arg('nickname')); @@ -35,24 +35,24 @@ class ShowstreamAction extends StreamAction { if (!$user) { $this->no_such_user(); - } + } $profile = $user->getProfile(); if (!$profile) { common_server_error(_t('User record exists without profile.')); } - + # Looks like we're good; show the header - + common_show_header($profile->nickname); $cur = common_current_user(); - + if ($cur && $profile->id == $cur->id) { $this->notice_form(); } - + $this->show_profile($profile); $this->show_last_notice($profile); @@ -64,20 +64,20 @@ class ShowstreamAction extends StreamAction { $this->show_subscribe_form($profile); } } - + $this->show_statistics($profile); $this->show_subscriptions($profile); - + $this->show_notices($profile); - + common_show_footer(); } - + function no_such_user() { common_user_error('No such user'); } - + function notice_form() { common_element_start('form', array('id' => 'newnotice', 'method' => 'POST', 'action' => common_local_url('newnotice'))); @@ -85,7 +85,7 @@ class ShowstreamAction extends StreamAction { common_element('input', array('type' => 'submit'), 'Send'); common_element_end('form'); } - + function show_profile($profile) { common_element_start('div', 'profile'); $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); @@ -99,7 +99,7 @@ class ShowstreamAction extends StreamAction { common_element('span', 'nickname', $profile->nickname); if ($profile->fullname) { if ($profile->homepage) { - common_element('a', array('href' => $profile->homepage, + common_element('a', array('href' => $profile->homepage, 'class' => 'fullname'), $profile->fullname); } else { @@ -135,42 +135,45 @@ class ShowstreamAction extends StreamAction { common_element('input', array('type' => 'submit'), _t('unsubscribe')); common_element_end('form'); } - + function show_subscriptions($profile) { - + # XXX: add a limit $subs = $profile->getLink('id', 'subscription', 'subscriber'); + common_element_start('div', 'subscriptions'); - + $cnt = 0; - - while ($subs->fetch()) { - $cnt++; - if ($cnt % SUBSCRIPTIONS_PER_ROW == 1) { - common_element_start('div', 'row'); - } - common_element_start('a', array('title' => $subs->fullname || - $subs->nickname, - 'href' => $subs->profileurl, - 'class' => 'subscription')); - $avatar = $subs->getAvatar(AVATAR_MINI_SIZE); - common_element('img', array('src' => (($avatar) ? $avatar->url : DEFAULT_MINI_AVATAR), - 'width' => AVATAR_MINI_SIZE, + 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->nickname, + 'href' => $subs->profileurl, + 'class' => 'subscription')); + $avatar = $subs->getAvatar(AVATAR_MINI_SIZE); + common_element('img', array('src' => (($avatar) ? $avatar->url : DEFAULT_MINI_AVATAR), + 'width' => AVATAR_MINI_SIZE, 'height' => AVATAR_MINI_SIZE, - 'class' => 'avatar mini')); - common_element_end('a'); - - if ($cnt % SUBSCRIPTIONS_PER_ROW == 0) { - common_element_end('div'); - } - - if ($cnt == SUBSCRIPTIONS) { - break; + 'class' => 'avatar mini')); + common_element_end('a'); + + if ($cnt % SUBSCRIPTIONS_PER_ROW == 0) { + common_element_end('div'); + } + + if ($cnt == SUBSCRIPTIONS) { + break; + } } } - common_element('a', array('href' => common_local_url('subscriptions', + common_element('a', array('href' => common_local_url('subscriptions', array('nickname' => $profile->nickname)), 'class' => 'moresubscriptions'), _t('All subscriptions')); @@ -184,15 +187,15 @@ class ShowstreamAction extends StreamAction { $subs = DB_DataObject::factory('subscription'); $subs->subscriber = $profile->id; $subs_count = $subs->count(); - + $subbed = DB_DataObject::factory('subscription'); $subbed->subscribed = $profile->id; $subbed_count = $subbed->count(); - + $notices = DB_DataObject::factory('notice'); $notices->profile_id = $profile->id; $notice_count = $notices->count(); - + # Other stats...? common_element_start('dl', 'statistics'); common_element('dt', _t('Subscriptions')); @@ -203,39 +206,39 @@ class ShowstreamAction extends StreamAction { common_element('dd', $notice_count); common_element_end('dl'); } - + function show_notices($profile) { $notice = DB_DataObject::factory('notice'); $notice->profile_id = $profile->id; - + $notice->orderBy('created DESC'); - + $page = $this->arg('page') || 1; - + $notice->limit((($page-1)*NOTICES_PER_PAGE) + 1, NOTICES_PER_PAGE); - + $notice->find(); common_element_start('div', 'notices'); - + while ($notice->fetch()) { $this->show_notice($notice); } - + common_element_end('div'); } - + function show_last_notice($profile) { $notice = DB_DataObject::factory('notice'); $notice->profile_id = $profile->id; $notice->orderBy('created DESC'); $notice->limit(1, 1); $notice->find(); - + while ($notice->fetch()) { # FIXME: URL, image, video, audio - common_element('span', array('class' => 'content'), + common_element('span', array('class' => 'content'), $notice->content); common_element('span', array('class' => 'date'), common_date_string($notice->created)); |