diff options
author | Evan Prodromou <evan@prodromou.name> | 2008-05-08 22:16:04 -0400 |
---|---|---|
committer | Evan Prodromou <evan@prodromou.name> | 2008-05-08 22:16:04 -0400 |
commit | f0a30cc89ddf82e3c774800d24f0ea3664065d9c (patch) | |
tree | 13053422786e83ab57a55e63879e5ceb07d9ecfd /actions/showstream.php | |
parent | 2df28057cdd5c54fb4f754f5c2222154efe2ad5b (diff) |
read-only stuff
darcs-hash:20080509021604-84dde-f785fc09dd435fc12741b3a75184e2425721d03d.gz
Diffstat (limited to 'actions/showstream.php')
-rw-r--r-- | actions/showstream.php | 199 |
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)); + } + } +} |