From 0b21ac3dd79d2bf39341a4f0ff3566def8282eae Mon Sep 17 00:00:00 2001 From: "matthew.gregg" Date: Sun, 22 Jun 2008 23:08:37 -0400 Subject: First pass at replies support http://laconi.ca/PITS/00080 Doesn't handle a reply to a user that has never updated. darcs-hash:20080623030837-982e4-532ccd8899fd8be00575f8840da0defb44cd56f8.gz --- actions/newnotice.php | 8 +++- actions/replies.php | 103 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 110 insertions(+), 1 deletion(-) create mode 100644 actions/replies.php (limited to 'actions') diff --git a/actions/newnotice.php b/actions/newnotice.php index 64fe2494b..9aaf4b4d3 100644 --- a/actions/newnotice.php +++ b/actions/newnotice.php @@ -36,6 +36,12 @@ class NewnoticeAction extends Action { function save_new_notice() { + #remember the current notice + $current_notice = DB_DataObject::factory('notice'); + $current_notice->limit(1); + $current_notice->orderBy('created DESC'); + $current_notice->find(1); + $user = common_current_user(); assert($user); # XXX: maybe an error instead... $notice = DB_DataObject::factory('notice'); @@ -67,7 +73,7 @@ class NewnoticeAction extends Action { common_server_error(_t('Problem saving notice.')); return; } - + common_broadcast_notice($notice); $returnto = $this->trimmed('returnto'); if ($returnto) { diff --git a/actions/replies.php b/actions/replies.php new file mode 100644 index 000000000..14f19cd76 --- /dev/null +++ b/actions/replies.php @@ -0,0 +1,103 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +require_once(INSTALLDIR.'/actions/showstream.php'); + +class RepliesAction extends StreamAction { + + 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"), + array($this, 'show_header'), $user, + array($this, 'show_top')); + + $this->show_replies($profile); + + common_show_footer(); + } + + function show_header($user) { + common_element('link', array('rel' => 'alternate', + 'href' => common_local_url('allrss', array('nickname' => + $user->nickname)), + 'type' => 'application/rss+xml', + 'title' => _t('Feed for friends of ') . $user->nickname)); + } + + function show_top($user) { + $cur = common_current_user(); + + $this->views_menu(); + } + + function show_replies($profile) { + + $reply = DB_DataObject::factory('reply'); + + $reply->user_id = $profile->id; + + $reply->orderBy('created DESC'); + + $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; + + $reply->limit((($page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1); + + $cnt = $reply->find(); + + if ($cnt > 0) { + common_element_start('ul', array('id' => 'replies')); + for ($i = 0; $i < min($cnt, REPLIES_PER_PAGE); $i++) { + if ($reply->fetch()) { + $notice = DB_DataObject::factory('notice'); + $notice->id = $reply->notice_id; + $notice->find(1); + $this->show_reply($notice, $reply->replied_id); + } else { + // shouldn't happen! + break; + } + } + common_element_end('ul'); + } + + common_pagination($page > 1, $cnt > REPLIES_PER_PAGE, + $page, 'all', array('nickname' => $profile->nickname)); + } +} -- cgit v1.2.3-54-g00ecf