reformat showstream
darcs-hash:20080520201120-84dde-4b455d4e4854454cc78be8c636a3e0c7f730b93a.gz
This commit is contained in:
parent
778fba1a24
commit
63758c59e1
@ -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()) {
|
||||||
|
@ -61,15 +61,7 @@ class NewnoticeAction extends Action {
|
|||||||
|
|
||||||
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();
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -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,23 +87,6 @@ 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) {
|
||||||
@ -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');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
13
doc/TODO
13
doc/TODO
@ -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
|
||||||
|
@ -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' =>
|
||||||
|
14
lib/util.php
14
lib/util.php
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user