function show_personal($profile) {
$avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
- if ($avatar) {
- common_element_start('div', array('id' => 'profile_avatar'));
- common_element('img', array('src' => $avatar->url,
- 'class' => 'avatar profile',
- 'width' => AVATAR_PROFILE_SIZE,
- 'height' => AVATAR_PROFILE_SIZE,
- 'alt' => $profile->nickname));
- $cur = common_current_user();
- if ($cur) {
- if ($cur->id != $profile->id) {
- if ($cur->isSubscribed($profile)) {
- $this->show_unsubscribe_form($profile);
- } else {
- $this->show_subscribe_form($profile);
- }
+ common_element_start('div', array('id' => 'profile_avatar'));
+ common_element('img', array('src' => ($avatar) ? $avatar->url : common_default_avatar(AVATAR_PROFILE_SIZE),
+ 'class' => 'avatar profile',
+ 'width' => AVATAR_PROFILE_SIZE,
+ 'height' => AVATAR_PROFILE_SIZE,
+ 'alt' => $profile->nickname));
+ $cur = common_current_user();
+ if ($cur) {
+ if ($cur->id != $profile->id) {
+ if ($cur->isSubscribed($profile)) {
+ $this->show_unsubscribe_form($profile);
+ } else {
+ $this->show_subscribe_form($profile);
}
- } else {
- $this->show_remote_subscribe_form($profile);
}
- common_element_end('div');
+ } else {
+ $this->show_remote_subscribe_form($profile);
}
+ common_element_end('div');
+
common_element_start('div', array('id' => 'profile_information'));
if ($profile->fullname) {
common_element('p', 'description', htmlspecialchars($profile->bio));
}
if ($profile->homepage) {
- common_element('p', 'website', $profile->homepage);
+ common_element_start('p', 'website');
+ common_element('a', array('href' => $profile->homepage),
+ $profile->homepage);
+ common_element_end('p');
}
$this->show_statistics($profile);
'type' => 'hidden',
'value' => $profile->nickname));
common_element('input', array('type' => 'submit',
- 'class' => 'button',
+ 'class' => 'submit',
'value' => _t('Subscribe')));
common_element_end('form');
}
'method' => 'POST',
'action' => common_local_url('remotesubscribe')));
common_hidden('nickname', $profile->nickname);
- common_element('input', array('name' => 'profile',
+ common_element('input', array('name' => 'profile_url',
'type' => 'text',
- 'id' => 'profile',
+ 'id' => 'profile_url',
'size' => '15'));
common_element('input', array('type' => 'submit',
'id' => 'submit',
'name' => 'submit',
'value' => _t('Subscribe'),
- 'class' => 'button'));
+ 'class' => 'submit'));
common_element_end('form');
}
'type' => 'hidden',
'value' => $profile->nickname));
common_element('input', array('type' => 'submit',
- 'class' => 'button',
+ 'class' => 'submit',
'value' => _t('Unsubscribe')));
common_element_end('form');
}
function show_subscriptions($profile) {
global $config;
- # XXX: add a limit
$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(0, SUBSCRIPTIONS);
+ $subs->limit(0, SUBSCRIPTIONS + 1);
$subs_count = $subs->find();
common_element_start('ul', array('id' => 'subscriptions_avatars'));
- while ($subs->fetch()) {
+ for ($i = 0; $i < min($subs_count, SUBSCRIPTIONS); $i++) {
+
+ if (!$subs->fetch()) {
+ common_debug('Weirdly, broke out of subscriptions loop early', __FILE__);
+ break;
+ }
$other = Profile::staticGet($subs->subscribed);
common_element_end('a');
common_element_end('li');
}
+
common_element_end('ul');
}
- common_element_start('p', array('id' => 'subscriptions_viewall'));
-
- common_element('a', array('href' => common_local_url('subscriptions',
- array('nickname' => $profile->nickname)),
- 'class' => 'moresubscriptions'),
- _t('All subscriptions'));
-
- common_element_end('p');
+ if ($subs_count > SUBSCRIPTIONS) {
+ common_element_start('p', array('id' => 'subscriptions_viewall'));
+
+ common_element('a', array('href' => common_local_url('subscriptions',
+ array('nickname' => $profile->nickname)),
+ 'class' => 'moresubscriptions'),
+ _t('All subscriptions'));
+ common_element_end('p');
+ }
common_element_end('div');
}
# Other stats...?
common_element_start('dl', 'statistics');
- common_element('dt', 'subscriptions', _t('Subscriptions'));
+ common_element_start('dt', 'subscriptions');
+ common_element('a', array('href' => common_local_url('subscriptions',
+ array('nickname' => $profile->nickname))),
+ _t('Subscriptions'));
+ common_element_end('dt');
common_element('dd', 'subscriptions', $subs_count);
- common_element('dt', 'subscribers', _t('Subscribers'));
+ common_element_start('dt', 'subscribers');
+ common_element('a', array('href' => common_local_url('subscribers',
+ array('nickname' => $profile->nickname))),
+ _t('Subscribers'));
+ common_element_end('dt');
common_element('dd', 'subscribers', $subbed_count);
common_element('dt', 'notices', _t('Notices'));
common_element('dd', 'notices', $notice_count);