convert tagother action
This commit is contained in:
parent
baaf55e9d6
commit
04d498784f
@ -23,71 +23,85 @@ require_once(INSTALLDIR.'/lib/settingsaction.php');
|
|||||||
|
|
||||||
class TagotherAction extends Action
|
class TagotherAction extends Action
|
||||||
{
|
{
|
||||||
|
var $profile = null;
|
||||||
|
var $error = null;
|
||||||
|
|
||||||
|
function prepare($args)
|
||||||
|
{
|
||||||
|
parent::prepare($args);
|
||||||
|
if (!common_logged_in()) {
|
||||||
|
$this->clientError(_('Not logged in'), 403);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$id = $this->trimmed('id');
|
||||||
|
if (!$id) {
|
||||||
|
$this->clientError(_('No id argument.'));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->profile = Profile::staticGet('id', $id);
|
||||||
|
|
||||||
|
if (!$this->profile) {
|
||||||
|
$this->clientError(_('No profile with that ID.'));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
function handle($args)
|
function handle($args)
|
||||||
{
|
{
|
||||||
|
|
||||||
parent::handle($args);
|
parent::handle($args);
|
||||||
|
|
||||||
if (!common_logged_in()) {
|
|
||||||
$this->clientError(_('Not logged in'), 403);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
|
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
|
||||||
$this->save_tags();
|
$this->saveTags();
|
||||||
} else {
|
} else {
|
||||||
$id = $this->trimmed('id');
|
$this->showForm($profile);
|
||||||
if (!$id) {
|
|
||||||
$this->clientError(_('No id argument.'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$profile = Profile::staticGet('id', $id);
|
|
||||||
if (!$profile) {
|
|
||||||
$this->clientError(_('No profile with that ID.'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$this->show_form($profile);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function show_form($profile, $error=null)
|
function title()
|
||||||
{
|
{
|
||||||
|
return sprintf(_('Tag %s'), $this->profile->nickname);
|
||||||
|
}
|
||||||
|
|
||||||
$user = common_current_user();
|
function showForm($error=null)
|
||||||
|
{
|
||||||
|
$this->error = $error;
|
||||||
|
$this->showPage();
|
||||||
|
}
|
||||||
|
|
||||||
common_show_header(_('Tag a person'),
|
function showContent()
|
||||||
null, array($profile, $error), array($this, 'show_top'));
|
{
|
||||||
|
$avatar = $this->profile->getAvatar(AVATAR_PROFILE_SIZE);
|
||||||
$avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
|
|
||||||
|
|
||||||
$this->element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_PROFILE_SIZE),
|
$this->element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_PROFILE_SIZE),
|
||||||
'class' => 'avatar stream',
|
'class' => 'avatar stream',
|
||||||
'width' => AVATAR_PROFILE_SIZE,
|
'width' => AVATAR_PROFILE_SIZE,
|
||||||
'height' => AVATAR_PROFILE_SIZE,
|
'height' => AVATAR_PROFILE_SIZE,
|
||||||
'alt' =>
|
'alt' =>
|
||||||
($profile->fullname) ? $profile->fullname :
|
($this->profile->fullname) ? $this->profile->fullname :
|
||||||
$profile->nickname));
|
$this->profile->nickname));
|
||||||
|
|
||||||
$this->element('a', array('href' => $profile->profileurl,
|
$this->element('a', array('href' => $this->profile->profileurl,
|
||||||
'class' => 'external profile nickname'),
|
'class' => 'external profile nickname'),
|
||||||
$profile->nickname);
|
$this->profile->nickname);
|
||||||
|
|
||||||
if ($profile->fullname) {
|
if ($this->profile->fullname) {
|
||||||
$this->elementStart('div', 'fullname');
|
$this->elementStart('div', 'fullname');
|
||||||
if ($profile->homepage) {
|
if ($this->profile->homepage) {
|
||||||
$this->element('a', array('href' => $profile->homepage),
|
$this->element('a', array('href' => $this->profile->homepage),
|
||||||
$profile->fullname);
|
$this->profile->fullname);
|
||||||
} else {
|
} else {
|
||||||
$this->text($profile->fullname);
|
$this->text($this->profile->fullname);
|
||||||
}
|
}
|
||||||
$this->elementEnd('div');
|
$this->elementEnd('div');
|
||||||
}
|
}
|
||||||
if ($profile->location) {
|
if ($this->profile->location) {
|
||||||
$this->element('div', 'location', $profile->location);
|
$this->element('div', 'location', $this->profile->location);
|
||||||
}
|
}
|
||||||
if ($profile->bio) {
|
if ($this->profile->bio) {
|
||||||
$this->element('div', 'bio', $profile->bio);
|
$this->element('div', 'bio', $this->profile->bio);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->elementStart('form', array('method' => 'post',
|
$this->elementStart('form', array('method' => 'post',
|
||||||
@ -95,33 +109,24 @@ class TagotherAction extends Action
|
|||||||
'name' => 'tagother',
|
'name' => 'tagother',
|
||||||
'action' => $this->selfUrl()));
|
'action' => $this->selfUrl()));
|
||||||
$this->hidden('token', common_session_token());
|
$this->hidden('token', common_session_token());
|
||||||
$this->hidden('id', $profile->id);
|
$this->hidden('id', $this->profile->id);
|
||||||
$this->input('tags', _('Tags'),
|
$this->input('tags', _('Tags'),
|
||||||
($this->arg('tags')) ? $this->arg('tags') : implode(' ', Profile_tag::getTags($user->id, $profile->id)),
|
($this->arg('tags')) ? $this->arg('tags') : implode(' ', Profile_tag::getTags($user->id, $this->profile->id)),
|
||||||
_('Tags for this user (letters, numbers, -, ., and _), comma- or space- separated'));
|
_('Tags for this user (letters, numbers, -, ., and _), comma- or space- separated'));
|
||||||
|
|
||||||
$this->submit('save', _('Save'));
|
$this->submit('save', _('Save'));
|
||||||
$this->elementEnd('form');
|
$this->elementEnd('form');
|
||||||
common_show_footer();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function save_tags()
|
function saveTags()
|
||||||
{
|
{
|
||||||
|
|
||||||
$id = $this->trimmed('id');
|
$id = $this->trimmed('id');
|
||||||
$tagstring = $this->trimmed('tags');
|
$tagstring = $this->trimmed('tags');
|
||||||
$token = $this->trimmed('token');
|
$token = $this->trimmed('token');
|
||||||
|
|
||||||
if (!$token || $token != common_session_token()) {
|
if (!$token || $token != common_session_token()) {
|
||||||
$this->show_form(_('There was a problem with your session token. Try again, please.'));
|
$this->showForm(_('There was a problem with your session token.'.
|
||||||
return;
|
' Try again, please.'));
|
||||||
}
|
|
||||||
|
|
||||||
$profile = Profile::staticGet('id', $id);
|
|
||||||
|
|
||||||
if (!$profile) {
|
|
||||||
$this->clientError(_('No such profile.'));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,7 +137,7 @@ class TagotherAction extends Action
|
|||||||
|
|
||||||
foreach ($tags as $tag) {
|
foreach ($tags as $tag) {
|
||||||
if (!common_valid_profile_tag($tag)) {
|
if (!common_valid_profile_tag($tag)) {
|
||||||
$this->show_form($profile, sprintf(_('Invalid tag: "%s"'), $tag));
|
$this->showForm(sprintf(_('Invalid tag: "%s"'), $tag));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -143,22 +148,22 @@ class TagotherAction extends Action
|
|||||||
$user = common_current_user();
|
$user = common_current_user();
|
||||||
|
|
||||||
if (!Subscription::pkeyGet(array('subscriber' => $user->id,
|
if (!Subscription::pkeyGet(array('subscriber' => $user->id,
|
||||||
'subscribed' => $profile->id)) &&
|
'subscribed' => $this->profile->id)) &&
|
||||||
!Subscription::pkeyGet(array('subscriber' => $profile->id,
|
!Subscription::pkeyGet(array('subscriber' => $this->profile->id,
|
||||||
'subscribed' => $user->id)))
|
'subscribed' => $user->id)))
|
||||||
{
|
{
|
||||||
$this->clientError(_('You can only tag people you are subscribed to or who are subscribed to you.'));
|
$this->clientError(_('You can only tag people you are subscribed to or who are subscribed to you.'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = Profile_tag::setTags($user->id, $profile->id, $tags);
|
$result = Profile_tag::setTags($user->id, $this->profile->id, $tags);
|
||||||
|
|
||||||
if (!$result) {
|
if (!$result) {
|
||||||
$this->clientError(_('Could not save tags.'));
|
$this->clientError(_('Could not save tags.'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$action = $user->isSubscribed($profile) ? 'subscriptions' : 'subscribers';
|
$action = $user->isSubscribed($this->profile) ? 'subscriptions' : 'subscribers';
|
||||||
|
|
||||||
if ($this->boolean('ajax')) {
|
if ($this->boolean('ajax')) {
|
||||||
common_start_html('text/xml');
|
common_start_html('text/xml');
|
||||||
@ -182,11 +187,10 @@ class TagotherAction extends Action
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function show_top($arr = null)
|
function showPageNotice()
|
||||||
{
|
{
|
||||||
list($profile, $error) = $arr;
|
if ($this->error) {
|
||||||
if ($error) {
|
$this->element('p', 'error', $this->error);
|
||||||
$this->element('p', 'error', $error);
|
|
||||||
} else {
|
} else {
|
||||||
$this->elementStart('div', 'instructions');
|
$this->elementStart('div', 'instructions');
|
||||||
$this->element('p', null,
|
$this->element('p', null,
|
||||||
|
Loading…
Reference in New Issue
Block a user