From: Evan Prodromou Date: Wed, 18 Jun 2008 17:13:13 +0000 (-0400) Subject: factor out similarities in subscriptions and subscribers X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=aeaf75138cf8be42d2e3935b708e1d24a97bd0a0;p=quix0rs-gnu-social.git factor out similarities in subscriptions and subscribers darcs-hash:20080618171313-84dde-3389db1f5110d3f47cd5a4ef17f6a7fc0fcf3b44.gz --- diff --git a/actions/subscribed.php b/actions/subscribed.php deleted file mode 100644 index d59af0a53d..0000000000 --- a/actions/subscribed.php +++ /dev/null @@ -1,108 +0,0 @@ -. - */ - -if (!defined('LACONICA')) { exit(1); } - -# XXX: make distinct from similar definitions in showstream.php - -define('SUBSCRIPTIONS_PER_ROW', 8); -define('SUBSCRIPTIONS_PER_PAGE', 80); - -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; - common_show_header($profile->nickname . ": " . _t('Subscribers'), - NULL, $profile, - array($this, 'show_top')); - $this->show_subscribed($profile, $page); - common_show_footer(); - } - - function show_top($profile) { - $user = common_current_user(); - common_element('p', 'instructions', - _t('These are the people who listen to ') . - (($user && ($user->id == $profile->id)) ? _t('your notices.') : ($profile->nickname . _t('\'s notices.')))); - } - - function show_subscribed($profile, $page) { - global $config; - - $subs = DB_DataObject::factory('subscription'); - $subs->subscribed = $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->subscriber); - - 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, 'subscribed', array('nickname' => $profile->nickname)); - } -} \ No newline at end of file diff --git a/actions/subscribers.php b/actions/subscribers.php new file mode 100644 index 0000000000..f5548d6535 --- /dev/null +++ b/actions/subscribers.php @@ -0,0 +1,46 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +require_once(INSTALLDIR.'/lib/gallery.php'); + +class SubscribersAction extends GalleryAction { + + function gallery_type() { + return _t('Subscribers'); + } + + function get_instructions(&$profile) { + $user =& common_current_user(); + if ($user && ($user->id == $profile->id)) { + return _t('These are the people who listen to your notices.'); + } else { + return _t('These are the people who listen to ') . $profile->nickname . _t('\'s notices.'); + } + } + + function define_subs(&$subs, &$profile) { + $subs->subscribed = $profile->id; + } + + function div_class() { + return 'subscribers'; + } +} \ No newline at end of file diff --git a/actions/subscriptions.php b/actions/subscriptions.php index e5db39bcec..aba974f6e9 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 diff --git a/lib/gallery.php b/lib/gallery.php new file mode 100644 index 0000000000..6d21b8310f --- /dev/null +++ b/lib/gallery.php @@ -0,0 +1,130 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +define('AVATARS_PER_ROW', 8); +define('AVATARS_PER_PAGE', 80); + +class GalleryAction extends Action { + + function handle($args) { + parent::handle($args); + $nickname = $this->arg('nickname'); + $profile = Profile::staticGet('nickname', $nickname); + if (!$profile) { + $this->no_such_user(); + return; + } + $user = User::staticGet($profile->id); + if (!$user) { + $this->no_such_user(); + return; + } + $page = $this->arg('page') || 1; + common_show_header($profile->nickname . ": " . $this->gallery_type(), + NULL, $profile, + array($this, 'show_top')); + $this->show_gallery($profile, $page); + common_show_footer(); + } + + function no_such_user() { + $this->client_error(_t('No such user.')); + } + + function show_top($profile) { + common_element('p', 'instructions', + $this->get_instructions($profile)); + } + + function show_gallery($profile, $page) { + + $subs = new Subscription(); + + $this->define_subs($subs, $profile); + + $subs->orderBy('created DESC'); + + # We ask for an extra one to know if we need to do another page + + $subs->limit((($page-1)*AVATARS_PER_PAGE), AVATARS_PER_PAGE + 1); + + $subs_count = $subs->find(); + + common_element_start('div', $this->div_class()); + + $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 == AVATARS_PER_PAGE) { + break; + } + } + + common_element_end('div'); + + common_pagination($page > 1, + $subs_count > AVATARS_PER_PAGE, + $page, + $this->trimmed('action'), + array('nickname' => $profile->nickname)); + } + + function gallery_type() { + return NULL; + } + + function get_instructions(&$profile) { + return NULL; + } + + function define_subs(&$subs, &$profile) { + return; + } + + function div_class() { + return ''; + } +} \ No newline at end of file