X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fshowstream.php;h=7e887a9d9ec00dd07698b792dc21d7863d8d06f8;hb=7352cab8ee8dd37c76ac2492695cc4c347d9564c;hp=c9b35ee0bbb4bc297e0733ea4f9e7173ec944846;hpb=a0bdc80053ce3b1d908aad6ab4a462b44b504e0c;p=quix0rs-gnu-social.git diff --git a/actions/showstream.php b/actions/showstream.php index c9b35ee0bb..7e887a9d9e 100644 --- a/actions/showstream.php +++ b/actions/showstream.php @@ -42,7 +42,7 @@ class ShowstreamAction extends StreamAction { if (!$profile) { common_server_error(_t('User record exists without profile.')); - return; + return; } # Looks like we're good; show the header @@ -52,14 +52,29 @@ class ShowstreamAction extends StreamAction { $cur = common_current_user(); if ($cur && $profile->id == $cur->id) { - $this->notice_form(); + common_notice_form(); } + $this->show_sidebar($profile); + + $this->show_notices($profile); + + common_show_footer(); + } + + function no_such_user() { + common_user_error('No such user'); + } + + function show_sidebar($profile) { + + common_element_start('div', 'sidebar width33 floatRight greenBg'); + $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 { @@ -71,51 +86,37 @@ class ShowstreamAction extends StreamAction { $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, - 'name' => 'content', - 'id' => 'content')); - common_element('input', array('type' => 'submit', 'value' => 'Send')); - common_element_end('form'); + common_element_end('div'); } - + function show_profile($profile) { common_element_start('div', 'profile'); + $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); if ($avatar) { common_element('img', array('src' => $avatar->url, 'class' => 'avatar profile', 'width' => AVATAR_PROFILE_SIZE, 'height' => AVATAR_PROFILE_SIZE, - 'title' => $profile->nickname)); + 'alt' => $profile->nickname)); } - common_element('span', 'nickname', $profile->nickname); if ($profile->fullname) { + common_element_start('div', 'fullname'); if ($profile->homepage) { - common_element('a', array('href' => $profile->homepage, - 'class' => 'fullname'), + common_element('a', array('href' => $profile->homepage), $profile->fullname); } else { - common_element('span', 'fullname', $profile->fullname); + common_text($profile->fullname); } + common_element_end('div'); } if ($profile->location) { - common_element('span', 'location', $profile->location); + common_element('div', 'location', $profile->location); } if ($profile->bio) { common_element('div', 'bio', $profile->bio); } + common_element_end('div'); } function show_subscribe_form($profile) { @@ -125,7 +126,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'); } @@ -136,17 +137,20 @@ class ShowstreamAction extends StreamAction { 'name' => 'unsubscribeto', 'type' => 'hidden', 'value' => $profile->nickname)); - common_element('input', array('type' => 'submit'), _t('unsubscribe')); + common_element('input', array('type' => 'submit'), _t('Unsubscribe')); common_element_end('form'); } function show_subscriptions($profile) { - + global $config; + # XXX: add a limit $subs = $profile->getLink('id', 'subscription', 'subscriber'); common_element_start('div', 'subscriptions'); + common_element('h2', 'subscriptions', _t('Subscriptions')); + $cnt = 0; if ($subs) { @@ -156,15 +160,19 @@ class ShowstreamAction extends StreamAction { common_element_start('div', 'row'); } - common_element_start('a', array('title' => $subs->fullname || + common_element_start('a', array('title' => ($subs->fullname) ? + $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), + common_element('img', array('src' => (($avatar) ? $avatar->url : $config['avatar']['default']['mini']), 'width' => AVATAR_MINI_SIZE, - 'height' => AVATAR_MINI_SIZE, - 'class' => 'avatar mini')); + 'height' => AVATAR_MINI_SIZE, + 'class' => 'avatar mini', + 'alt' => ($subs->fullname) ? + $subs->fullname : + $subs->nickname)); common_element_end('a'); if ($cnt % SUBSCRIPTIONS_PER_ROW == 0) { @@ -192,23 +200,40 @@ class ShowstreamAction extends StreamAction { $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'); $notices->profile_id = $profile->id; $notice_count = $notices->count(); + if (!$notice_count) { + $notice_count = 0; + } + + common_element_start('div', 'statistics'); + common_element('h2', 'statistics', _t('Statistics')); + # Other stats...? common_element_start('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_element('dt', 'subscriptions', _t('Subscriptions')); + common_element('dd', 'subscriptions', $subs_count); + common_element('dt', 'subscribers', _t('Subscribers')); + common_element('dd', 'subscribers', $subbed_count); + common_element('dt', 'notices', _t('Notices')); + common_element('dd', 'notices', $notice_count); common_element_end('dl'); + + common_element_end('div'); } function show_notices($profile) { @@ -220,32 +245,55 @@ class ShowstreamAction extends StreamAction { $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'); + common_element_start('div', 'notices width66 floatLeft'); + common_element_start('ul', 'bigLinks'); + while ($notice->fetch()) { $this->show_notice($notice); } - + + common_element_end('ul'); + + # XXX: show a link for the next page common_element_end('div'); } function show_last_notice($profile) { + + common_element_start('div', 'lastnotice'); + common_element('h2', 'lastnotice', _t('Currently')); + $notice = DB_DataObject::factory('notice'); $notice->profile_id = $profile->id; $notice->orderBy('created DESC'); - $notice->limit(1, 1); - $notice->find(); + $notice->limit(0, 1); - while ($notice->fetch()) { + if ($notice->find(true)) { # FIXME: URL, image, video, audio common_element('span', array('class' => 'content'), $notice->content); - common_element('span', array('class' => 'date'), - common_date_string($notice->created)); } + + common_element_end('div'); + } + + function show_notice($notice) { + $profile = $notice->getProfile(); + # XXX: RDFa + common_element_start('li', array('class' => 'notice', + 'id' => 'notice-' . $notice->id)); + $noticeurl = common_local_url('shownotice', array('notice' => $notice->id)); + # FIXME: URL, image, video, audio + common_element_start('a', array('class' => 'notice', + 'href' => $noticeurl)); + common_element('span', 'title', common_date_string($notice->created)); + common_element('span', 'desc', $notice->content); + common_element_end('a'); + common_element_end('li'); } }