Remove common code from Subscriptions, make tags link visible
This commit is contained in:
parent
9d913150d4
commit
01e7859a81
|
@ -2,7 +2,7 @@
|
|||
/**
|
||||
* Laconica, the distributed open-source microblogging tool
|
||||
*
|
||||
* User profile page
|
||||
* List of a user's subscriptions
|
||||
*
|
||||
* PHP version 5
|
||||
*
|
||||
|
@ -19,7 +19,7 @@
|
|||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
* @category Personal
|
||||
* @category Social
|
||||
* @package Laconica
|
||||
* @author Evan Prodromou <evan@controlyourself.ca>
|
||||
* @author Sarven Capadisli <csarven@controlyourself.ca>
|
||||
|
@ -32,18 +32,10 @@ if (!defined('LACONICA')) {
|
|||
exit(1);
|
||||
}
|
||||
|
||||
require_once INSTALLDIR.'/lib/subsgroupnav.php';
|
||||
|
||||
/**
|
||||
* User profile page
|
||||
* A list of the user's subscriptions
|
||||
*
|
||||
* When I created this page, "show stream" seemed like the best name for it.
|
||||
* Now, it seems like a really bad name.
|
||||
*
|
||||
* It shows a stream of the user's posts, plus lots of profile info, links
|
||||
* to subscriptions and stuff, etc.
|
||||
*
|
||||
* @category Personal
|
||||
* @category Social
|
||||
* @package Laconica
|
||||
* @author Evan Prodromou <evan@controlyourself.ca>
|
||||
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
|
||||
|
@ -52,62 +44,8 @@ require_once INSTALLDIR.'/lib/subsgroupnav.php';
|
|||
|
||||
if (!defined('LACONICA')) { exit(1); }
|
||||
|
||||
class SubscriptionsAction extends Action
|
||||
class SubscriptionsAction extends GalleryAction
|
||||
{
|
||||
var $profile = null;
|
||||
var $user = null;
|
||||
var $page = null;
|
||||
|
||||
function prepare($args)
|
||||
{
|
||||
parent::prepare($args);
|
||||
|
||||
// FIXME very similar code below
|
||||
|
||||
$nickname_arg = $this->arg('nickname');
|
||||
$nickname = common_canonical_nickname($nickname_arg);
|
||||
|
||||
// Permanent redirect on non-canonical nickname
|
||||
|
||||
if ($nickname_arg != $nickname) {
|
||||
$args = array('nickname' => $nickname);
|
||||
if ($this->arg('page') && $this->arg('page') != 1) {
|
||||
$args['page'] = $this->arg['page'];
|
||||
}
|
||||
common_redirect(common_local_url('subscriptions', $args), 301);
|
||||
return false;
|
||||
}
|
||||
|
||||
$this->user = User::staticGet('nickname', $nickname);
|
||||
|
||||
if (!$this->user) {
|
||||
$this->clientError(_('No such user.'), 404);
|
||||
return false;
|
||||
}
|
||||
|
||||
$this->profile = $this->user->getProfile();
|
||||
|
||||
if (!$this->profile) {
|
||||
$this->serverError(_('User has no profile.'));
|
||||
return false;
|
||||
}
|
||||
|
||||
$this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
function isReadOnly()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
function handle($args)
|
||||
{
|
||||
parent::handle($args);
|
||||
$this->showPage();
|
||||
}
|
||||
|
||||
function title()
|
||||
{
|
||||
if ($this->page == 1) {
|
||||
|
@ -134,21 +72,22 @@ class SubscriptionsAction extends Action
|
|||
}
|
||||
}
|
||||
|
||||
function showLocalNav()
|
||||
function getAllTags()
|
||||
{
|
||||
$nav = new SubGroupNav($this, $this->user);
|
||||
$nav->show();
|
||||
return $this->getTags('subscribed', 'subscriber');
|
||||
}
|
||||
|
||||
function showContent()
|
||||
{
|
||||
parent::showContent();
|
||||
|
||||
$offset = ($this->page-1) * PROFILES_PER_PAGE;
|
||||
$limit = PROFILES_PER_PAGE + 1;
|
||||
|
||||
$subscriptions = $this->user->getSubscriptions($offset, $limit);
|
||||
|
||||
if ($subs) {
|
||||
$subscriptions_list = new SubscriptionsList($subscriptions, null, $this);
|
||||
if ($subscriptions) {
|
||||
$subscriptions_list = new SubscriptionsList($subscriptions, $this->user, $this);
|
||||
$subscriptions_list->show();
|
||||
}
|
||||
|
||||
|
@ -170,16 +109,16 @@ class SubscriptionsList extends ProfileList
|
|||
return;
|
||||
}
|
||||
|
||||
$this->elementStart('form', array('id' => 'subedit-' . $profile->id,
|
||||
$this->out->elementStart('form', array('id' => 'subedit-' . $profile->id,
|
||||
'method' => 'post',
|
||||
'class' => 'subedit',
|
||||
'action' => common_local_url('subedit')));
|
||||
$this->hidden('token', common_session_token());
|
||||
$this->hidden('profile', $profile->id);
|
||||
$this->checkbox('jabber', _('Jabber'), $sub->jabber);
|
||||
$this->checkbox('sms', _('SMS'), $sub->sms);
|
||||
$this->submit('save', _('Save'));
|
||||
$this->elementEnd('form');
|
||||
$this->out->hidden('token', common_session_token());
|
||||
$this->out->hidden('profile', $profile->id);
|
||||
$this->out->checkbox('jabber', _('Jabber'), $sub->jabber);
|
||||
$this->out->checkbox('sms', _('SMS'), $sub->sms);
|
||||
$this->out->submit('save', _('Save'));
|
||||
$this->out->elementEnd('form');
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -99,9 +99,6 @@ display:none;
|
|||
margin-left:11px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* FORM SETTINGS */
|
||||
.form_settings fieldset {
|
||||
margin-bottom:29px;
|
||||
|
@ -111,7 +108,6 @@ margin-bottom:29px;
|
|||
font-style:italic;
|
||||
}
|
||||
|
||||
|
||||
.form_settings .form_data li {
|
||||
width:100%;
|
||||
float:left;
|
||||
|
@ -179,7 +175,6 @@ width:90%;
|
|||
margin-left:0;
|
||||
}
|
||||
|
||||
|
||||
.form_settings .form_note {
|
||||
border-radius:4px;
|
||||
-moz-border-radius:4px;
|
||||
|
@ -187,13 +182,8 @@ border-radius:4px;
|
|||
padding:0 7px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* FORM SETTINGS */
|
||||
|
||||
|
||||
|
||||
|
||||
address {
|
||||
float:left;
|
||||
margin-bottom:18px;
|
||||
|
@ -206,7 +196,6 @@ address .fn {
|
|||
font-weight:bold;
|
||||
}
|
||||
|
||||
|
||||
#header {
|
||||
width:100%;
|
||||
position:relative;
|
||||
|
@ -225,7 +214,6 @@ display:inline;
|
|||
margin-left:11px;
|
||||
}
|
||||
|
||||
|
||||
.system_notice dt {
|
||||
font-weight:bold;
|
||||
text-transform:uppercase;
|
||||
|
@ -244,17 +232,12 @@ clear:both;
|
|||
margin-bottom:18px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
#footer {
|
||||
float:left;
|
||||
width:64%;
|
||||
padding:18px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#site_nav_local_views {
|
||||
width:100%;
|
||||
float:left;
|
||||
|
@ -286,7 +269,6 @@ float:left;
|
|||
width:100%;
|
||||
}
|
||||
|
||||
|
||||
#site_nav_global_primary dt,
|
||||
#site_nav_global_secondary dt {
|
||||
display:none;
|
||||
|
@ -315,8 +297,6 @@ padding-left:30px;
|
|||
padding-left:28px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#export_data ul {
|
||||
display:inline;
|
||||
}
|
||||
|
@ -329,8 +309,6 @@ margin-left:11px;
|
|||
margin-left:0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#licenses {
|
||||
font-size:0.9em;
|
||||
}
|
||||
|
@ -353,7 +331,6 @@ vertical-align:top;
|
|||
margin-right:4px;
|
||||
}
|
||||
|
||||
|
||||
#wrap {
|
||||
float:left;
|
||||
margin:0 auto;
|
||||
|
@ -361,7 +338,6 @@ margin-right:4px;
|
|||
width:71.714em;
|
||||
}
|
||||
|
||||
|
||||
#core {
|
||||
position:relative;
|
||||
width:100%;
|
||||
|
@ -396,9 +372,6 @@ border-radius:7px;
|
|||
-webkit-border-radius:7px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*Start: FORM NOTICE*/
|
||||
#form_notice {
|
||||
width:384px;
|
||||
|
@ -501,10 +474,6 @@ float:left;
|
|||
|
||||
/*end FORM NOTICE*/
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* entity_profile */
|
||||
.entity_profile {
|
||||
position:relative;
|
||||
|
@ -575,10 +544,6 @@ display:none;
|
|||
|
||||
/* entity_profile */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*entity_actions*/
|
||||
.entity_actions {
|
||||
float:right;
|
||||
|
@ -617,8 +582,6 @@ font-weight:bold;
|
|||
display:block;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.form_user_block input.submit,
|
||||
.form_user_unblock input.submit,
|
||||
#entity_send-a-message a,
|
||||
|
@ -633,8 +596,6 @@ padding-left:20px;
|
|||
padding:4px 4px 4px 23px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.entity_tags ul {
|
||||
list-style-type:none;
|
||||
}
|
||||
|
@ -644,8 +605,6 @@ margin-right:1em;
|
|||
float:left;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.aside .section {
|
||||
margin-bottom:29px;
|
||||
clear:both;
|
||||
|
@ -665,7 +624,6 @@ display:inline;
|
|||
content: ":";
|
||||
}
|
||||
|
||||
|
||||
#user_subscriptions,
|
||||
#user_subscribers,
|
||||
#user_groups, {
|
||||
|
@ -692,8 +650,6 @@ display:none;
|
|||
clear:both;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.profile .entity_profile {
|
||||
margin-bottom:0;
|
||||
min-height:60px;
|
||||
|
@ -708,7 +664,6 @@ float:right;
|
|||
display:none;
|
||||
}
|
||||
|
||||
|
||||
.profiles {
|
||||
list-style-type:none;
|
||||
}
|
||||
|
@ -730,8 +685,6 @@ display:block;
|
|||
width:auto;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* NOTICE */
|
||||
.notice,
|
||||
.profile {
|
||||
|
@ -756,7 +709,6 @@ border-radius:4px;
|
|||
-webkit-border-radius:4px;
|
||||
}
|
||||
|
||||
|
||||
/* NOTICES */
|
||||
#notices_primary {
|
||||
float:left;
|
||||
|
@ -773,7 +725,6 @@ display:block;
|
|||
padding-left:28px;
|
||||
}
|
||||
|
||||
|
||||
.notice .author {
|
||||
margin-right:11px;
|
||||
}
|
||||
|
@ -802,7 +753,6 @@ font-style:italic;
|
|||
|
||||
}
|
||||
|
||||
|
||||
.notice .entry-title {
|
||||
float:left;
|
||||
width:100%;
|
||||
|
@ -875,8 +825,6 @@ text-transform:lowercase;
|
|||
.notice div.entry-content a:hover {
|
||||
}
|
||||
|
||||
|
||||
|
||||
.notice-data {
|
||||
position:absolute;
|
||||
top:18px;
|
||||
|
@ -966,10 +914,6 @@ padding:0;
|
|||
|
||||
/*END: NOTICES */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
.pagination dt {
|
||||
font-weight:bold;
|
||||
display:none;
|
||||
|
@ -1010,11 +954,8 @@ padding-right:20px;
|
|||
border-right:0;
|
||||
}
|
||||
|
||||
|
||||
/* END: NOTICE */
|
||||
|
||||
|
||||
|
||||
/*If there is hentry on #content_inner, then this doesn't need to be specific to #doc or any other section */
|
||||
.hentry .entry-content p {
|
||||
margin-bottom:18px;
|
||||
|
@ -1030,7 +971,6 @@ margin-bottom:18px;
|
|||
margin-left:18px;
|
||||
}
|
||||
|
||||
|
||||
/*START: LOAD ALONG WITH JS*/
|
||||
.notice .in-reply-to {
|
||||
width:98%;
|
||||
|
@ -1046,8 +986,6 @@ background-color:#E4E9F0;
|
|||
background-color:#D1D9E4;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.entity_actions #user_subscribe .form_note,
|
||||
.entity_actions #user_subscribe .form_data,
|
||||
.entity_actions #user_subscribe .form_actions label {
|
||||
|
@ -1079,8 +1017,6 @@ background-color:#fff;
|
|||
|
||||
/*END: LOAD ALONG WITH JS*/
|
||||
|
||||
|
||||
|
||||
/* TOP_POSTERS */
|
||||
#top-posters caption {
|
||||
text-align:left;
|
||||
|
@ -1106,8 +1042,6 @@ height:24px;
|
|||
width:24px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* tagcloud */
|
||||
.tag-cloud {
|
||||
list-style-type:none;
|
||||
|
@ -1150,15 +1084,10 @@ font-size:4em;
|
|||
display:none;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
#form_settings_photo .form_data {
|
||||
clear:both;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#form_settings_avatar li {
|
||||
width:auto;
|
||||
}
|
||||
|
@ -1188,8 +1117,6 @@ clear:both;
|
|||
margin-bottom:0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#groups_related ul,
|
||||
#users_featured ul {
|
||||
list-style-type:none;
|
||||
|
@ -1223,8 +1150,6 @@ display:none;
|
|||
font-weight:bold;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#home.logged_out h1 {
|
||||
display:none;
|
||||
}
|
||||
|
@ -1267,7 +1192,10 @@ font-weight:bold;
|
|||
text-align:center;
|
||||
}
|
||||
|
||||
|
||||
#testimonials {
|
||||
clear:both;
|
||||
}
|
||||
|
||||
.entity_tags dt {
|
||||
display:block;
|
||||
}
|
Loading…
Reference in New Issue
Block a user