summaryrefslogtreecommitdiff
path: root/actions
diff options
context:
space:
mode:
Diffstat (limited to 'actions')
-rw-r--r--actions/all.php32
-rw-r--r--actions/public.php39
-rw-r--r--actions/shownotice.php45
-rw-r--r--actions/showstream.php199
-rw-r--r--actions/subscribed.php80
-rw-r--r--actions/subscriptions.php77
6 files changed, 441 insertions, 31 deletions
diff --git a/actions/all.php b/actions/all.php
new file mode 100644
index 000000000..fa1be8c96
--- /dev/null
+++ b/actions/all.php
@@ -0,0 +1,32 @@
+<?php
+
+class AllAction extends ShowstreamAction {
+
+ // XXX: push this up to a common function.
+
+ function show_notices($profile) {
+
+ $notice = DB_DataObject::factory('notice');
+
+ # XXX: chokety and bad
+
+ $notice->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = {$profile->id})', 'OR');
+ $notice->whereAdd('profile_id = {$profile->id}', 'OR');
+
+ $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');
+ }
+}
diff --git a/actions/public.php b/actions/public.php
new file mode 100644
index 000000000..e52ec12de
--- /dev/null
+++ b/actions/public.php
@@ -0,0 +1,39 @@
+<?php
+
+class PublicAction extends StreamAction {
+
+ function handle($args) {
+ parent::handle($args);
+
+ $page = $this->arg('page') || 1;
+
+ common_show_header(_t('Public timeline'));
+
+ # XXX: Public sidebar here?
+
+ $this->show_notices($page);
+
+ common_show_footer();
+ }
+
+ function show_notices($page) {
+
+ $notice = DB_DataObject::factory('notice');
+
+ # XXX: filter out private notifications
+
+ $notice->orderBy('created DESC');
+ $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');
+ }
+}
+
diff --git a/actions/shownotice.php b/actions/shownotice.php
new file mode 100644
index 000000000..4d4876122
--- /dev/null
+++ b/actions/shownotice.php
@@ -0,0 +1,45 @@
+<?php
+
+class ShownoticeAction extends Action {
+
+ function handle($args) {
+ parent::handle($args);
+ $id = $this->arg('notice');
+ $notice = Notice::staticGet($id);
+
+ if (!$notice) {
+ $this->no_such_notice();
+ }
+
+ if (!$notice->getProfile()) {
+ $this->no_such_notice();
+ }
+
+ # Looks like we're good; show the header
+
+ common_show_header($profile->nickname);
+
+ $this->show_notice($notice);
+
+ common_show_footer();
+ }
+
+ function no_such_notice() {
+ common_user_error('No such notice.');
+ }
+
+ function show_notice($notice) {
+ $profile = $notice->getProfile();
+ # XXX: RDFa
+ common_start_element('div', array('class' => 'notice'));
+ # FIXME: add the avatar
+ common_start_element('a', array('href' => $profile->profileurl,
+ 'class' => 'nickname'),
+ $profile->nickname);
+ # 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_end_element('div');
+ }
+}
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));
+ }
+ }
+}
diff --git a/actions/subscribed.php b/actions/subscribed.php
new file mode 100644
index 000000000..6ba452eb9
--- /dev/null
+++ b/actions/subscribed.php
@@ -0,0 +1,80 @@
+<?php
+
+class SubscribedAction extends Action {
+
+ # Who is subscribed to a given user?
+
+ function handle($args) {
+ parent::handle($args);
+ $nickname = $this->arg('nickname');
+ $profile = Profile::staticGet('nickname', $nickname);
+ if (!$profile) {
+ $this->no_such_user();
+ }
+ $user = User::staticGet($profile->id);
+ if (!$user) {
+ $this->no_such_user();
+ }
+
+ $page = $this->arg('page') || 1;
+ $this->show_subscribed($profile, $page);
+ }
+
+ function show_subscribed($profile, $page) {
+
+ $sub = DB_DataObject::factory('subscriptions');
+ $sub->subscribed = $profile->id;
+
+ # We ask for an extra one to know if we need to do another page
+
+ $sub->limit((($page-1)*SUBSCRIPTIONS_PER_PAGE)+1, SUBSCRIPTIONS_PER_PAGE + 1);
+
+ $subs_count = $subs->find();
+
+ common_start_element('div', 'subscriptions');
+
+ $idx = 0;
+
+ while ($subs->fetch()) {
+ $idx++;
+ if ($idx % 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 ($idx % SUBSCRIPTIONS_PER_ROW == 0) {
+ common_end_element('div');
+ }
+
+ if ($idx == SUBSCRIPTIONS_PER_PAGE) {
+ break;
+ }
+ }
+
+ if ($page > 1) {
+ common_element('a', array('href' =>
+ common_local_url('subscriptions',
+ array('nickname' => $profile->nickname,
+ 'page' => $page - 1)),
+ 'class' => 'prev'),
+ _t('Previous'));
+ }
+
+ if ($subs_count > SUBSCRIPTIONS_PER_PAGE) {
+ common_element('a', array('href' =>
+ common_local_url('subscriptions',
+ array('nickname' => $profile->nickname,
+ 'page' => $page + 1)),
+ 'class' => 'next'),
+ _t('Next'));
+ }
+ common_end_element('div');
+ }
+} \ No newline at end of file
diff --git a/actions/subscriptions.php b/actions/subscriptions.php
new file mode 100644
index 000000000..88e12f5d5
--- /dev/null
+++ b/actions/subscriptions.php
@@ -0,0 +1,77 @@
+<?php
+
+class SubscriptionsAction extends Action {
+
+ function handle($args) {
+ parent::handle($args);
+ $nickname = $this->arg('nickname');
+ $profile = Profile::staticGet('nickname', $nickname);
+ if (!$profile) {
+ $this->no_such_user();
+ }
+ $user = User::staticGet($profile->id);
+ if (!$user) {
+ $this->no_such_user();
+ }
+ $page = $this->arg('page') || 1;
+ $this->show_subscriptions($profile, $page);
+ }
+
+ function show_subscriptions($profile, $page) {
+
+ $sub = DB_DataObject::factory('subscriptions');
+ $sub->subscriber = $profile->id;
+
+ # We ask for an extra one to know if we need to do another page
+
+ $sub->limit((($page-1)*SUBSCRIPTIONS_PER_PAGE)+1, SUBSCRIPTIONS_PER_PAGE + 1);
+
+ $subs_count = $subs->find();
+
+ common_start_element('div', 'subscriptions');
+
+ $idx = 0;
+
+ while ($subs->fetch()) {
+ $idx++;
+ if ($idx % 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 ($idx % SUBSCRIPTIONS_PER_ROW == 0) {
+ common_end_element('div');
+ }
+
+ if ($idx == SUBSCRIPTIONS_PER_PAGE) {
+ break;
+ }
+ }
+
+ if ($page > 1) {
+ common_element('a', array('href' =>
+ common_local_url('subscriptions',
+ array('nickname' => $profile->nickname,
+ 'page' => $page - 1)),
+ 'class' => 'prev'),
+ _t('Previous'));
+ }
+
+ if ($subs_count > SUBSCRIPTIONS_PER_PAGE) {
+ common_element('a', array('href' =>
+ common_local_url('subscriptions',
+ array('nickname' => $profile->nickname,
+ 'page' => $page + 1)),
+ 'class' => 'next'),
+ _t('Next'));
+ }
+ common_end_element('div');
+ }
+} \ No newline at end of file