summaryrefslogtreecommitdiff
path: root/actions/subscriptions.php
diff options
context:
space:
mode:
authorEvan Prodromou <evan@prodromou.name>2008-06-18 13:13:13 -0400
committerEvan Prodromou <evan@prodromou.name>2008-06-18 13:13:13 -0400
commitaeaf75138cf8be42d2e3935b708e1d24a97bd0a0 (patch)
tree20d54fffb3f63dd8caa86af7a126bf26a7f2f5c7 /actions/subscriptions.php
parentf055d2643be700ea9be6bd4b61b49111244b31a2 (diff)
factor out similarities in subscriptions and subscribers
darcs-hash:20080618171313-84dde-3389db1f5110d3f47cd5a4ef17f6a7fc0fcf3b44.gz
Diffstat (limited to 'actions/subscriptions.php')
-rw-r--r--actions/subscriptions.php92
1 files changed, 15 insertions, 77 deletions
diff --git a/actions/subscriptions.php b/actions/subscriptions.php
index e5db39bce..aba974f6e 100644
--- a/actions/subscriptions.php
+++ b/actions/subscriptions.php
@@ -19,90 +19,28 @@
if (!defined('LACONICA')) { exit(1); }
-# XXX: make distinct from similar definitions in showstream.php
+require_once(INSTALLDIR.'/lib/gallery.php');
-define('SUBSCRIPTIONS_PER_ROW', 8);
-define('SUBSCRIPTIONS_PER_PAGE', 80);
+class SubscriptionsAction extends GalleryAction {
-class SubscriptionsAction extends Action {
+ function gallery_type() {
+ return _t('Subscriptions');
+ }
- 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();
+ function get_instructions(&$profile) {
+ $user =& common_current_user();
+ if ($user && ($user->id == $profile->id)) {
+ return _t('These are the people whose notices you listen to.');
+ } else {
+ return _t('These are the people whose notices ') . $profile->nickname . _t(' listens to.');
}
- $page = $this->arg('page') || 1;
- common_show_header($profile->nickname . ": " . _t('Subscriptions'),
- NULL, $profile,
- array($this, 'show_top'));
- $this->show_subscriptions($profile, $page);
- common_show_footer();
}
- function show_top($profile) {
- $user = common_current_user();
- common_element('p', 'instructions',
- _t('These are the people whose notices ') .
- (($user && ($user->id == $profile->id)) ? _t('you listen to.') : ($profile->nickname . _t(' listens to.'))));
+ function define_subs(&$subs, &$profile) {
+ $subs->subscriber = $profile->id;
}
- function show_subscriptions($profile, $page) {
-
- $subs = DB_DataObject::factory('subscription');
- $subs->subscriber = $profile->id;
-
- $subs->orderBy('created DESC');
-
- # We ask for an extra one to know if we need to do another page
-
- $subs->limit((($page-1)*SUBSCRIPTIONS_PER_PAGE), SUBSCRIPTIONS_PER_PAGE + 1);
-
- $subs_count = $subs->find();
-
- common_element_start('div', 'subscriptions');
-
- $idx = 0;
-
- while ($subs->fetch()) {
-
- $idx++;
-
- $other = Profile::staticGet($subs->subscribed);
-
- common_element_start('a', array('title' => ($other->fullname) ?
- $other->fullname :
- $other->nickname,
- 'href' => $other->profileurl,
- 'class' => 'subscription'));
- $avatar = $other->getAvatar(AVATAR_STREAM_SIZE);
- common_element('img',
- array('src' =>
- (($avatar) ? $avatar->url :
- common_default_avatar(AVATAR_STREAM_SIZE)),
- 'width' => AVATAR_STREAM_SIZE,
- 'height' => AVATAR_STREAM_SIZE,
- 'class' => 'avatar stream',
- 'alt' => ($other->fullname) ?
- $other->fullname :
- $other->nickname));
- common_element_end('a');
-
- # XXX: subscribe form here
-
- if ($idx == SUBSCRIPTIONS_PER_PAGE) {
- break;
- }
- }
-
- common_element_end('div');
-
- common_pagination($page > 1, $subs_count > SUBSCRIPTIONS_PER_PAGE,
- $page, 'subscriptions', array('nickname' => $profile->nickname));
+ function div_class() {
+ return 'subscriptions';
}
} \ No newline at end of file