summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvan Prodromou <evan@prodromou.name>2008-05-17 15:24:47 -0400
committerEvan Prodromou <evan@prodromou.name>2008-05-17 15:24:47 -0400
commit30089235e0c6e7008217f54cc4b65a686c4e0600 (patch)
treef01c485f64ca80d0e8bd0c5edb6da5bebe56d450
parent726e8fdaf70402e5f658af38b13620972af8ebdf (diff)
handle empty subscription list
darcs-hash:20080517192447-84dde-f8dc1f4befde5d7624887b13eb7f5730f693c72c.gz
-rw-r--r--actions/showstream.php115
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));