]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/showstream.php
better deletion of old avatars
[quix0rs-gnu-social.git] / actions / showstream.php
index 1f9fb935d4596ed2968aa3b67dfc0e93151015ff..82a55518da60fdfafca3b770d25847d853a45757 100644 (file)
@@ -1,89 +1,95 @@
 <?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/>.
  */
 
 if (!defined('LACONICA')) { exit(1); }
 
+require_once(INSTALLDIR.'/lib/stream.php');
+
 define('SUBSCRIPTIONS_PER_ROW', 5);
 define('SUBSCRIPTIONS', 80);
 
 class ShowstreamAction extends StreamAction {
 
        function handle($args) {
-               
+
                parent::handle($args);
 
-               $nickname = common_canonicalize_nickname($this->arg('profile'));
+               $nickname = common_canonical_nickname($this->arg('nickname'));
                $user = User::staticGet('nickname', $nickname);
 
                if (!$user) {
                        $this->no_such_user();
-               } 
+                       return;
+               }
 
                $profile = $user->getProfile();
 
                if (!$profile) {
                        common_server_error(_t('User record exists without profile.'));
+                       return;                 
                }
-               
+
                # 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);
 
-               if ($cur) {
+               if ($cur && $cur->id != $profile->id) {
                        if ($cur->isSubscribed($profile)) {
                                $this->show_unsubscribe_form($profile);
                        } else {
                                $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')));
-               common_element('textarea', array('rows' => 4, 'cols' => 80, 'id' => 'content'));
-               common_element('input', array('type' => 'submit'), 'Send');
+               common_element('textarea', array('rows' => 4, 'cols' => 80,
+                                                                                'name' => 'content', 
+                                                                                'id' => 'content'));
+               common_element('input', array('type' => 'submit', 'value' => 'Send'));
                common_element_end('form');
        }
-       
+
        function show_profile($profile) {
                common_element_start('div', 'profile');
                $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
@@ -97,7 +103,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 {
@@ -119,7 +125,7 @@ class ShowstreamAction extends StreamAction {
                                                                          'name' => 'subscribeto',
                                                                          'type' => 'hidden',
                                                                          'value' => $profile->nickname));
-               common_element('input', array('type' => 'submit'), _t('subscribe'));
+               common_element('input', array('type' => 'submit', 'value' => _t('Subscribe')));
                common_element_end('form');
        }
 
@@ -133,43 +139,46 @@ 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', 
-                                                                                                                        array('profile' => $profile->nickname)),
+               common_element('a', array('href' => common_local_url('subscriptions',
+                                                                                                                        array('nickname' => $profile->nickname)),
                                                                  'class' => 'moresubscriptions'),
                                           _t('All subscriptions'));
 
@@ -182,15 +191,27 @@ class ShowstreamAction extends StreamAction {
                $subs = DB_DataObject::factory('subscription');
                $subs->subscriber = $profile->id;
                $subs_count = $subs->count();
+
+               if (!$subs_count) {
+                       $subs_count = 0;
+               }
                
                $subbed = DB_DataObject::factory('subscription');
                $subbed->subscribed = $profile->id;
                $subbed_count = $subbed->count();
+
+               if (!$subbed_count) {
+                       $subbed_count = 0;
+               }
                
                $notices = DB_DataObject::factory('notice');
-               $notice->profile_id = $profile->id;
-               $notice_count = $notice->count();
+               $notices->profile_id = $profile->id;
+               $notice_count = $notices->count();
                
+               if (!$notice_count) {
+                       $notice_count = 0;
+               }
+
                # Other stats...?
                common_element_start('dl', 'statistics');
                common_element('dt', _t('Subscriptions'));
@@ -201,39 +222,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->limit((($page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE);
+
                $notice->find();
 
                common_element_start('div', 'notices');
-               
+
                while ($notice->fetch()) {
                        $this->show_notice($notice);
                }
-               
+               # XXX: show a link for the next page
                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->limit(0, 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));