reformat showstream

darcs-hash:20080520201120-84dde-4b455d4e4854454cc78be8c636a3e0c7f730b93a.gz
This commit is contained in:
Evan Prodromou 2008-05-20 16:11:20 -04:00
parent 778fba1a24
commit 63758c59e1
6 changed files with 94 additions and 44 deletions

View File

@ -21,9 +21,41 @@ if (!defined('LACONICA')) { exit(1); }
require_once(INSTALLDIR.'/actions/showstream.php'); require_once(INSTALLDIR.'/actions/showstream.php');
class AllAction extends ShowstreamAction { class AllAction extends StreamAction {
// XXX: push this up to a common function. function handle($args) {
parent::handle($args);
$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 . _t(" and friends"));
$cur = common_current_user();
if ($cur && $profile->id == $cur->id) {
common_notice_form();
}
$this->show_notices($profile);
common_show_footer();
}
function show_notices($profile) { function show_notices($profile) {
@ -42,7 +74,7 @@ class AllAction extends ShowstreamAction {
$notice->find(); $notice->find();
common_element_start('div', 'notices'); common_element_start('div', 'notices width100');
common_element('h2', 'notices', _t('Notices')); common_element('h2', 'notices', _t('Notices'));
while ($notice->fetch()) { while ($notice->fetch()) {

View File

@ -58,18 +58,10 @@ class NewnoticeAction extends Action {
return NULL; return NULL;
} }
} }
function show_form() { function show_form() {
common_show_header(_t('New notice')); common_show_header(_t('New notice'));
common_element_start('form', array('id' => 'newnotice', 'method' => 'POST', common_notice_form();
'action' => common_local_url('newnotice')));
common_element('span', 'nickname', $profile->nickname);
common_element('textarea', array('rows' => 3, 'cols' => 60,
'name' => 'content',
'id' => 'content'),
' ');
common_submit('submit', _t('Send'));
common_element_end('form');
common_show_footer(); common_show_footer();
} }
} }

View File

@ -52,12 +52,23 @@ class ShowstreamAction extends StreamAction {
$cur = common_current_user(); $cur = common_current_user();
if ($cur && $profile->id == $cur->id) { if ($cur && $profile->id == $cur->id) {
$this->notice_form(); common_notice_form();
} }
$this->show_notices($profile); $this->show_notices($profile);
common_element_start('div', 'sidebar width33 floatRight greenBg'); $this->show_sidebar($profile);
common_show_footer();
}
function no_such_user() {
common_user_error('No such user');
}
function show_sidebar($profile) {
common_element_start('div', 'sidebar width25 floatRight greenBg');
$this->show_profile($profile); $this->show_profile($profile);
@ -76,25 +87,8 @@ class ShowstreamAction extends StreamAction {
$this->show_subscriptions($profile); $this->show_subscriptions($profile);
common_element_end('div'); common_element_end('div');
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' => 3, 'cols' => 60,
'name' => 'content',
'id' => 'content'),
' ');
common_submit('submit', _t('Send'));
common_element_end('form');
}
function show_profile($profile) { function show_profile($profile) {
common_element_start('div', 'profile'); common_element_start('div', 'profile');
@ -255,12 +249,16 @@ class ShowstreamAction extends StreamAction {
$notice->find(); $notice->find();
common_element_start('div', 'notices width66 floatLeft'); common_element_start('div', 'notices width75 floatLeft');
common_element('h2', 'notices', _t('Notices'));
common_element_start('ul', 'bigLinks');
while ($notice->fetch()) { while ($notice->fetch()) {
$this->show_notice($notice); $this->show_notice($notice);
} }
common_element_end('ul');
# XXX: show a link for the next page # XXX: show a link for the next page
common_element_end('div'); common_element_end('div');
} }
@ -279,10 +277,22 @@ class ShowstreamAction extends StreamAction {
# FIXME: URL, image, video, audio # FIXME: URL, image, video, audio
common_element('span', array('class' => 'content'), common_element('span', array('class' => 'content'),
$notice->content); $notice->content);
common_element('span', array('class' => 'date'),
common_date_string($notice->created));
} }
common_element_end('div'); 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('li');
}
} }

View File

@ -36,8 +36,8 @@
+ show current values in profile settings + show current values in profile settings
+ save profile URL in profilesettings + save profile URL in profilesettings
+ save profile URL on registration + save profile URL on registration
- require valid nicknames + require valid nicknames
- reject empty notices + reject empty notices
- store canonical username for comparison and fetch - store canonical username for comparison and fetch
- use only canonical usernames - use only canonical usernames
- use only canonical email addresses - use only canonical email addresses
@ -46,17 +46,20 @@
- RSS 1.0 feed of all public notices - RSS 1.0 feed of all public notices
- RDF dump of entire site - RDF dump of entire site
- FOAF dump for user - FOAF dump for user
- license on showstream + license on showstream
- license on shownotice + license on shownotice
- TOS checkbox on register - TOS checkbox on register
- pretty URLs - pretty URLs
- site logo - site logo
- instructions - instructions
- deal with PHP quotes escaping - deal with PHP quotes escaping
- fix layout of textarea - fix layout of textarea
- make notices into "big links" + make notices into "big links"
- fix spacing on notices - fix spacing on notices
- limit entry in textarea to 140 chars - limit entry in textarea to 140 chars
- add a next page link to showstream
- add a next page link to public
- add a next page link to all
- release 0.2 - release 0.2
- set Last-Modified - set Last-Modified
- XML sitemap generation - XML sitemap generation

View File

@ -27,7 +27,6 @@ class StreamAction extends Action {
parent::handle($args); parent::handle($args);
} }
# XXX: for 'showstream' repeats same avatar over and over
function show_notice($notice) { function show_notice($notice) {
$profile = $notice->getProfile(); $profile = $notice->getProfile();
# XXX: RDFa # XXX: RDFa
@ -36,7 +35,7 @@ class StreamAction extends Action {
$avatar = $profile->getAvatar(AVATAR_STREAM_SIZE); $avatar = $profile->getAvatar(AVATAR_STREAM_SIZE);
common_element_start('a', array('href' => $profile->profileurl)); common_element_start('a', array('href' => $profile->profileurl));
common_element('img', array('src' => ($avatar) ? $avatar->url : DEFAULT_STREAM_AVATAR, common_element('img', array('src' => ($avatar) ? $avatar->url : DEFAULT_STREAM_AVATAR,
'class' => 'avatar stream floatLeft', 'class' => 'avatar stream',
'width' => AVATAR_STREAM_SIZE, 'width' => AVATAR_STREAM_SIZE,
'height' => AVATAR_STREAM_SIZE, 'height' => AVATAR_STREAM_SIZE,
'alt' => 'alt' =>

View File

@ -377,6 +377,20 @@ function common_profile_url($nickname) {
return common_local_url('showstream', array('nickname' => $nickname)); return common_local_url('showstream', array('nickname' => $nickname));
} }
function common_notice_form() {
common_element_start('form', array('id' => 'newnotice', 'method' => 'POST',
'action' => common_local_url('newnotice')));
common_element_start('p');
common_element('label', array('for' => 'content'), _t('What\'s up?'));
common_element('textarea', array('rows' => 3, 'cols' => 40,
'name' => 'content',
'id' => 'content',
'class' => 'width75'),
' ');
common_submit('submit', _t('Send'));
common_element_end('form');
}
// XXX: set up gettext // XXX: set up gettext
function _t($str) { function _t($str) {