summaryrefslogtreecommitdiff
path: root/actions/showstream.php
diff options
context:
space:
mode:
Diffstat (limited to 'actions/showstream.php')
-rw-r--r--actions/showstream.php199
1 files changed, 168 insertions, 31 deletions
diff --git a/actions/showstream.php b/actions/showstream.php
index d3352e77d..1eb060fdc 100644
--- a/actions/showstream.php
+++ b/actions/showstream.php
@@ -1,45 +1,182 @@
<?php
-function handle_showstream() {
-
- $user_name = $_REQUEST['profile'];
- $profile = Profile::staticGet('nickname', $user_name);
+define('SUBSCRIPTIONS_PER_ROW', 5);
+define('SUBSCRIPTIONS', 80);
+
+class ShowstreamAction extends StreamAction {
+
+ function handle($args) {
+
+ parent::handle($args);
+
+ $nickname = $this->arg('profile');
+ $profile = Profile::staticGet('nickname', strtolower($nickname));
- if (!$profile) {
- showstream_no_such_user();
- }
+ if (!$profile) {
+ $this->no_such_user();
+ }
+
+ $user = User::staticGet($profile->id);
+
+ if (!$user) {
+ // remote profile
+ $this->no_such_user();
+ }
+
+ # Looks like we're good; show the header
+
+ common_show_header($profile->nickname);
+
+ if ($profile->id == current_user()->id) {
+ $this->notice_form();
+ }
- $user = User::staticGet($profile->id);
+ $this->show_profile($profile);
- if (!$user) {
- // remote profile
- showstream_no_such_user();
+ $this->show_last_notice($profile);
+
+ $this->show_statistics($profile);
+
+ $this->show_subscriptions($profile);
+
+ $this->show_notices($profile);
+
+ common_show_footer();
}
-
- if ($profile->id == current_user()->id) {
- showstream_notice_form();
+
+ function no_such_user() {
+ common_user_error('No such user');
}
- showstream_show_profile($profile);
-
- $notice = DB_DataObject::factory('notice');
- $notice->profile_id = $profile->id;
- $notice->limit(1, 10);
+ function notice_form() {
+ common_start_element('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_end_element('form');
+ }
- $notice->find();
+ function show_profile($profile) {
+ common_start_element('div', 'profile');
+ common_element('span', 'nickname', $profile->nickname);
+ if ($profile->fullname) {
+ if ($profile->homepage) {
+ common_element('a', array('href' => $profile->homepage,
+ 'class' => 'fullname'),
+ $profile->fullname);
+ } else {
+ common_element('span', 'fullname', $profile->fullname);
+ }
+ }
+ if ($profile->location) {
+ common_element('span', 'location', $profile->location);
+ }
+ if ($profile->bio) {
+ common_element('div', 'bio', $profile->bio);
+ }
+ }
- while ($notice->fetch()) {
- showstream_show_notice($notice);
+ function show_subscriptions($profile) {
+
+ # XXX: add a limit
+
+ $subs = $profile->getLink('id', 'subscription', 'subscriber');
+
+ common_start_element('div', 'subscriptions');
+
+ $cnt = 0;
+
+ while ($subs->fetch()) {
+ $cnt++;
+ if ($cnt % SUBSCRIPTIONS_PER_ROW == 1) {
+ common_start_element('div', 'row');
+ }
+
+ common_start_element('a', array('title' => $subs->fullname ||
+ $subs->nickname,
+ 'href' => $subs->profileurl,
+ 'class' => 'subscription'));
+ common_element('img', array('src' => $subs->avatar,
+ 'class' => 'avatar'));
+ common_end_element('a');
+
+ if ($cnt % SUBSCRIPTIONS_PER_ROW == 0) {
+ common_end_element('div');
+ }
+
+ if ($cnt == SUBSCRIPTIONS) {
+ break;
+ }
+ }
+
+ common_element('a', array('href' => common_local_url('subscriptions',
+ array('profile' => $profile->nickname))
+ 'class' => 'moresubscriptions'),
+ _t('All subscriptions'));
+
+ common_end_element('div');
}
-}
-function showstream_no_such_user() {
- common_user_error('No such user');
-}
+ function show_statistics($profile) {
-function showstream_notice_form() {
- // print notice form
-}
+ // XXX: WORM cache this
+ $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');
+ $notice->profile_id = $profile->id;
+ $notice_count = $notice->count();
+
+ # Other stats...?
+ common_start_element('dl', 'statistics');
+ common_element('dt', _t('Subscriptions'));
+ common_element('dd', $subs_count);
+ common_element('dt', _t('Subscribers'));
+ common_element('dd', $subbed_count);
+ common_element('dt', _t('Notices'));
+ common_element('dd', $notice_count);
+ common_end_element('dl');
+ }
+
+ function show_notices($profile) {
-function showstream_show_profile($profile) {
-} \ No newline at end of file
+ $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_start_element('div', 'notices');
+
+ while ($notice->fetch()) {
+ $this->show_notice($notice);
+ }
+
+ common_end_element('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'), $notice->content);
+ common_element('span', array('class' => 'date'),
+ common_date_string($notice->created));
+ }
+ }
+}