if (empty($this->request)) {
// TRANS: Client error displayed trying to approve group membership for a non-existing request.
+ // TRANS: %s is a nickname.
$this->clientError(sprintf(_('%s is not in the moderation queue for this group.'), $this->profile->nickname), 403);
}
$this->elementEnd('head');
$this->elementStart('body');
if ($this->approve) {
- // TRANS: Message on page for group admin after approving a join request.
+ // TRANS: Message on page for group admin after approving a join request.
$this->element('p', 'success', _('Join request approved.'));
} elseif ($this->cancel) {
- // TRANS: Message on page for group admin after rejecting a join request.
+ // TRANS: Message on page for group admin after rejecting a join request.
$this->element('p', 'success', _('Join request canceled.'));
}
$this->elementEnd('body');
/**
* StatusNet, the distributed open-source microblogging tool
*
- * Leave a group
+ * Approve group subscription request
*
* PHP version 5
*
StatusNet::setApi(true);
}
if (!common_logged_in()) {
+ // TRANS: Client error displayed when trying to leave a group while not logged in.
$this->clientError(_('Not logged in.'));
return;
}
$other_id = $this->arg('unsubscribeto');
if (!$other_id) {
+ // TRANS: Client error displayed when trying to leave a group without specifying an ID.
$this->clientError(_('No profile ID in request.'));
return;
}
$other = Profile::staticGet('id', $other_id);
if (!$other) {
+ // TRANS: Client error displayed when trying to leave a non-existing group.
$this->clientError(_('No profile with that ID.'));
return;
}
if ($this->boolean('ajax')) {
$this->startHTML('text/xml;charset=utf-8');
$this->elementStart('head');
- $this->element('title', null, _('Unsubscribed'));
+ // TRANS: Title after unsubscribing from a group.
+ $this->element('title', null, _m('TITLE','Unsubscribed'));
$this->elementEnd('head');
$this->elementStart('body');
$subscribe = new SubscribeForm($this, $other);
}
}
+// @todo FIXME: documentation missing.
class GroupQueueList extends GroupMemberList
{
function newListItem($profile)
}
}
+// @todo FIXME: documentation missing.
class GroupQueueListItem extends GroupMemberListItem
{
function showActions()
exit(1);
}
-
-
/**
* Change profile settings
*
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class ProfilesettingsAction extends SettingsAction
{
/**
// TRANS: Tooltip for field label in form for profile settings. Plural
// TRANS: is decided by the number of characters available for the
// TRANS: biography (%d).
- $bioInstr = sprintf(_m('Describe yourself and your interests in %d character',
- 'Describe yourself and your interests in %d characters',
+ $bioInstr = sprintf(_m('Describe yourself and your interests in %d character.',
+ 'Describe yourself and your interests in %d characters.',
$maxBio),
$maxBio);
} else {
// TRANS: Tooltip for field label in form for profile settings.
- $bioInstr = _('Describe yourself and your interests');
+ $bioInstr = _('Describe yourself and your interests.');
}
- // TRANS: Text area label in form for profile settings where users can provide.
+ // TRANS: Text area label in form for profile settings where users can provide
// TRANS: their biography.
$this->textarea('bio', _('Bio'),
($this->arg('bio')) ? $this->arg('bio') : $profile->bio,
$this->input('location', _('Location'),
($this->arg('location')) ? $this->arg('location') : $profile->location,
// TRANS: Tooltip for field label in form for profile settings.
- _('Where you are, like "City, State (or Region), Country"'));
+ _('Where you are, like "City, State (or Region), Country".'));
$this->elementEnd('li');
if (common_config('location', 'share') == 'user') {
$this->elementStart('li');
$this->dropdown('subscribe_policy',
// TRANS: Dropdown field label on profile settings, for what policies to apply when someone else tries to subscribe to your updates.
_('Subscription policy'),
+ // TRANS: Dropdown field option for following policy.
array(User::SUBSCRIBE_POLICY_OPEN => _('Let anyone follow me'),
+ // TRANS: Dropdown field option for following policy.
User::SUBSCRIBE_POLICY_MODERATE => _('Ask me first')),
// TRANS: Dropdown field title on group edit form.
_('Whether other users need your permission to follow your updates.'),
$this->elementEnd('li');
}
$this->elementEnd('ul');
- // TRANS: Field label on account registration page.
+ // TRANS: Botton text to register a user on account registration page.
$this->submit('submit', _m('BUTTON','Register'));
$this->elementEnd('fieldset');
$this->elementEnd('form');
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class SnapshotadminpanelAction extends AdminPanelAction
{
/**
*
* @return string page title
*/
-
function title()
{
- return _('Snapshots');
+ // TRANS: Title for admin panel to configure snapshots.
+ return _m('TITLE','Snapshots');
}
/**
*
* @return string instructions
*/
-
function getInstructions()
{
+ // TRANS: Instructions for admin panel to configure snapshots.
return _('Manage snapshot configuration');
}
*
* @return void
*/
-
function showForm()
{
$form = new SnapshotAdminPanelForm($this);
*
* @return void
*/
-
function saveSettings()
{
static $settings = array(
// Validate snapshot run value
if (!in_array($values['snapshot']['run'], array('web', 'cron', 'never'))) {
+ // TRANS: Client error displayed on admin panel for snapshots when providing an invalid run value.
$this->clientError(_('Invalid snapshot run value.'));
}
// Validate snapshot frequency value
if (!Validate::number($values['snapshot']['frequency'])) {
+ // TRANS: Client error displayed on admin panel for snapshots when providing an invalid value for frequency.
$this->clientError(_('Snapshot frequency must be a number.'));
}
array('allowed_schemes' => array('http', 'https')
)
)) {
+ // TRANS: Client error displayed on admin panel for snapshots when providing an invalid report URL.
$this->clientError(_('Invalid snapshot report URL.'));
}
}
}
+// @todo FIXME: add documentation
class SnapshotAdminPanelForm extends AdminForm
{
/**
*
* @return int ID of the form
*/
-
function id()
{
return 'form_snapshot_admin_panel';
*
* @return string class of the form
*/
-
function formClass()
{
return 'form_settings';
*
* @return string URL of the action
*/
-
function action()
{
return common_local_url('snapshotadminpanel');
*
* @return void
*/
-
function formData()
{
$this->out->elementStart(
'fieldset',
array('id' => 'settings_admin_snapshots')
);
- $this->out->element('legend', null, _('Snapshots'));
+ // TRANS: Fieldset legend on admin panel for snapshots.
+ $this->out->element('legend', null, _m('LEGEND','Snapshots'));
$this->out->elementStart('ul', 'form_data');
$this->li();
$snapshot = array(
+ // TRANS: Option in dropdown for snapshot method in admin panel for snapshots.
'web' => _('Randomly during web hit'),
+ // TRANS: Option in dropdown for snapshot method in admin panel for snapshots.
'cron' => _('In a scheduled job'),
+ // TRANS: Option in dropdown for snapshot method in admin panel for snapshots.
'never' => _('Never')
);
$this->out->dropdown(
'run',
+ // TRANS: Dropdown label for snapshot method in admin panel for snapshots.
_('Data snapshots'),
$snapshot,
- _('When to send statistical data to status.net servers'),
+ // TRANS: Dropdown title for snapshot method in admin panel for snapshots.
+ _('When to send statistical data to status.net servers.'),
false,
$this->value('run', 'snapshot')
);
$this->li();
$this->input(
'frequency',
+ // TRANS: Input field label for snapshot frequency in admin panel for snapshots.
_('Frequency'),
- _('Snapshots will be sent once every N web hits'),
+ // TRANS: Input field title for snapshot frequency in admin panel for snapshots.
+ _('Snapshots will be sent once every N web hits.'),
'snapshot'
);
$this->unli();
$this->li();
$this->input(
'reporturl',
+ // TRANS: Input field label for snapshot report URL in admin panel for snapshots.
_('Report URL'),
- _('Snapshots will be sent to this URL'),
+ // TRANS: Input field title for snapshot report URL in admin panel for snapshots.
+ _('Snapshots will be sent to this URL.'),
'snapshot'
);
$this->unli();
*
* @return void
*/
-
function formActions()
{
$this->out->submit(
'submit',
- _('Save'),
+ // TRANS: Button text to save snapshot settings.
+ _m('BUTTON','Save'),
'submit',
null,
- _('Save snapshot settings')
+ // TRANS: Title for button to save snapshot settings.
+ _('Save snapshot settings.')
);
}
}
if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
+// @todo FIXME: documentation missing.
class TagAction extends Action
{
-
var $notice;
function prepare($args)
$this->notice = Notice_tag::getStream($this->tag, (($this->page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1);
if($this->page > 1 && $this->notice->N == 0){
- // TRANS: Server error when page not found (404)
+ // TRANS: Server error when page not found (404).
$this->serverError(_('No such page.'),$code=404);
}
return array(new Feed(Feed::RSS1,
common_local_url('tagrss',
array('tag' => $this->tag)),
+ // TRANS: Link label for feed on "notices with tag" page.
+ // TRANS: %s is the tag the feed is for.
sprintf(_('Notice feed for tag %s (RSS 1.0)'),
$this->tag)),
new Feed(Feed::RSS2,
common_local_url('ApiTimelineTag',
array('format' => 'rss',
'tag' => $this->tag)),
+ // TRANS: Link label for feed on "notices with tag" page.
+ // TRANS: %s is the tag the feed is for.
sprintf(_('Notice feed for tag %s (RSS 2.0)'),
$this->tag)),
new Feed(Feed::ATOM,
common_local_url('ApiTimelineTag',
array('format' => 'atom',
'tag' => $this->tag)),
+ // TRANS: Link label for feed on "notices with tag" page.
+ // TRANS: %s is the tag the feed is for.
sprintf(_('Notice feed for tag %s (Atom)'),
$this->tag)));
}
function showContent()
{
if(Event::handle('StartTagShowContent', array($this))) {
-
+
$nl = new NoticeList($this->notice, $this);
$cnt = $nl->show();
{
parent::prepare($args);
if (!common_logged_in()) {
+ // TRANS: Client error displayed on user tag page when trying to add tags while not logged in.
$this->clientError(_('Not logged in.'), 403);
return false;
}
$id = $this->trimmed('id');
if (!$id) {
+ // TRANS: Client error displayed on user tag page when trying to add tags without providing a user ID.
$this->clientError(_('No ID argument.'));
return false;
}
$this->profile = Profile::staticGet('id', $id);
if (!$this->profile) {
+ // TRANS: Client error displayed on user tag page when trying to add tags providing a non-existing user ID.
$this->clientError(_('No profile with that ID.'));
return false;
}
function title()
{
+ // TRANS: Title for "tag other users" page.
+ // TRANS: %s is the user nickname.
return sprintf(_('Tag %s'), $this->profile->nickname);
}
function showContent()
{
$this->elementStart('div', 'entity_profile vcard author');
+ // TRANS: Header for user details on "tag other users" page.
$this->element('h2', null, _('User profile'));
$avatar = $this->profile->getAvatar(AVATAR_PROFILE_SIZE);
'action' => common_local_url('tagother', array('id' => $this->profile->id))));
$this->elementStart('fieldset');
+ // TRANS: Fieldset legend on "tag other users" page.
$this->element('legend', null, _('Tag user'));
$this->hidden('token', common_session_token());
$this->hidden('id', $this->profile->id);
$this->elementStart('ul', 'form_data');
$this->elementStart('li');
+ // TRANS: Field label for inputting tags on "tag other users" page.
$this->input('tags', _('Tags'),
($this->arg('tags')) ? $this->arg('tags') : implode(' ', Profile_tag::getTags($user->id, $this->profile->id)),
+ // TRANS: Title for input field for inputting tags on "tag other users" page.
_('Tags for this user (letters, numbers, -, ., and _), separated by commas or spaces.'));
$this->elementEnd('li');
$this->elementEnd('ul');
+ // TRANS: Button text for saving tags for other users.
$this->submit('save', _m('BUTTON','Save'));
$this->elementEnd('fieldset');
$this->elementEnd('form');
!Subscription::pkeyGet(array('subscriber' => $this->profile->id,
'subscribed' => $user->id)))
{
+ // TRANS: Client error on "tag other users" page when tagging a user is not possible because of missing mutual subscriptions.
$this->clientError(_('You can only tag people you are subscribed to or who are subscribed to you.'));
return;
}
$result = Profile_tag::setTags($user->id, $this->profile->id, $tags);
if (!$result) {
+ // TRANS: Client error on "tag other users" page when saving tags fails server side.
$this->clientError(_('Could not save tags.'));
return;
}
if ($this->boolean('ajax')) {
$this->startHTML('text/xml;charset=utf-8');
$this->elementStart('head');
- $this->element('title', null, _('Tags'));
+ // TRANS: Title of "tag other users" page.
+ $this->element('title', null, _m('TITLE','Tags'));
$this->elementEnd('head');
$this->elementStart('body');
$this->elementStart('p', 'subtags');
} else {
$this->elementStart('div', 'instructions');
$this->element('p', null,
+ // TRANS: Page notice on "tag other users" page.
_('Use this form to add tags to your subscribers or subscriptions.'));
$this->elementEnd('div');
}
require_once(INSTALLDIR.'/lib/rssaction.php');
// Formatting of RSS handled by Rss10Action
-
class TagrssAction extends Rss10Action
{
var $tag;
$tag = common_canonical_tag($this->trimmed('tag'));
$this->tag = Notice_tag::staticGet('tag', $tag);
if (!$this->tag) {
+ // TRANS: Client error when requesting a tag feed for a non-existing tag.
$this->clientError(_('No such tag.'));
return false;
} else {
$c = array('url' => common_local_url('tagrss', array('tag' => $tagname)),
'title' => $tagname,
'link' => common_local_url('tagrss', array('tag' => $tagname)),
+ // TRANS: Tag feed description.
+ // TRANS: %1$s is the tag name, %2$s is the StatusNet sitename.
'description' => sprintf(_('Updates tagged with %1$s on %2$s!'),
$tagname, common_config('site', 'name')));
return $c;
* @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
* @link http://status.net/
*/
-
class UnsandboxAction extends ProfileFormAction
{
/**
*
* @return boolean success flag
*/
-
function prepare($args)
{
if (!parent::prepare($args)) {
assert(!empty($cur)); // checked by parent
if (!$cur->hasRight(Right::SANDBOXUSER)) {
+ // TRANS: Client error on page to unsandbox a user when the feature is not enabled.
$this->clientError(_('You cannot sandbox users on this site.'));
return false;
}
assert(!empty($this->profile)); // checked by parent
if (!$this->profile->isSandboxed()) {
+ // TRANS: Client error on page to unsilence a user when the to be unsandboxed user has not been sandboxed.
$this->clientError(_('User is not sandboxed.'));
return false;
}
*
* @return void
*/
-
function handlePost()
{
$this->profile->unsandbox();
* @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
* @link http://status.net/
*/
-
class UnsilenceAction extends ProfileFormAction
{
/**
*
* @return boolean success flag
*/
-
function prepare($args)
{
if (!parent::prepare($args)) {
assert(!empty($cur)); // checked by parent
if (!$cur->hasRight(Right::SILENCEUSER)) {
+ // TRANS: Client error on page to unsilence a user when the feature is not enabled.
$this->clientError(_('You cannot silence users on this site.'));
return false;
}
assert(!empty($this->profile)); // checked by parent
if (!$this->profile->isSilenced()) {
+ // TRANS: Client error on page to unsilence a user when the to be unsilenced user has not been silenced.
$this->clientError(_('User is not silenced.'));
return false;
}
*
* @return void
*/
-
function handlePost()
{
$this->profile->unsilence();
*/
class UnsubscribeAction extends Action
{
-
function handle($args)
{
parent::handle($args);
if (!common_logged_in()) {
+ // TRANS: Client error displayed when trying to unsubscribe while not logged in.
$this->clientError(_('Not logged in.'));
return;
}
$other_id = $this->arg('unsubscribeto');
if (!$other_id) {
+ // TRANS: Client error displayed when trying to unsubscribe without providing a profile ID.
$this->clientError(_('No profile ID in request.'));
return;
}
$other = Profile::staticGet('id', $other_id);
if (!$other) {
+ // TRANS: Client error displayed when trying to unsubscribe while providing a non-existing profile ID.
$this->clientError(_('No profile with that ID.'));
return;
}
if ($this->boolean('ajax')) {
$this->startHTML('text/xml;charset=utf-8');
$this->elementStart('head');
+ // TRANS: Page title for page to unsubscribe.
$this->element('title', null, _('Unsubscribed'));
$this->elementEnd('head');
$this->elementStart('body');
*/
class UpdateprofileAction extends Action
{
-
/**
* For initializing members of the class.
*
$license = $_POST['omb_listenee_license'];
$site_license = common_config('license', 'url');
if (!common_compatible_license($license, $site_license)) {
- $this->clientError(sprintf(_('Listenee stream license ‘%1$s’ is not '.
- 'compatible with site license ‘%2$s’.'),
+ // TRANS: Client error displayed when trying to update profile with an incompatible license.
+ // TRANS: %1$s is the license incompatible with site license %2$s.
+ $this->clientError(sprintf(_('Listenee stream license "%1$s" is not '.
+ 'compatible with site license "%2$s".'),
$license, $site_license));
return false;
}
exit(1);
}
-
-
/**
* Miscellaneous settings actions
*
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class UrlsettingsAction extends SettingsAction
{
/**
*
* @return string Title of the page
*/
-
function title()
{
+ // TRANS: Title of URL settings tab in profile settings.
return _('URL settings');
}
*
* @return instructions for use
*/
-
function getInstructions()
{
// TRANS: Instructions for tab "Other" in user profile settings.
*
* @return void
*/
-
function showContent()
{
$user = common_current_user();
// Include default values
+ // TRANS: Default value for URL shortening settings.
$services['none'] = _('[none]');
+ // TRANS: Default value for URL shortening settings.
$services['internal'] = _('[internal]');
if ($services) {
-
asort($services);
$this->elementStart('li');
}
$this->elementStart('li');
$this->input('maxurllength',
+ // TRANS: Field label in URL settings in profile.
_('URL longer than'),
(!is_null($this->arg('maxurllength'))) ?
$this->arg('maxurllength') : User_urlshortener_prefs::maxUrlLength($user),
+ // TRANS: Field title in URL settings in profile.
_('URLs longer than this will be shortened, 0 means always shorten.'));
$this->elementEnd('li');
$this->elementStart('li');
$this->input('maxnoticelength',
+ // TRANS: Field label in URL settings in profile.
_('Text longer than'),
(!is_null($this->arg('maxnoticelength'))) ?
$this->arg('maxnoticelength') : User_urlshortener_prefs::maxNoticeLength($user),
+ // TRANS: Field title in URL settings in profile.
_('URLs in notices longer than this will be shortened, 0 means always shorten.'));
$this->elementEnd('li');
$this->elementEnd('ul');
*
* @return void
*/
-
function handlePost()
{
// CSRF protection
$maxurllength = $this->trimmed('maxurllength');
if (!Validate::number($maxurllength, array('min' => 0))) {
- throw new ClientException(_('Invalid number for max url length.'));
+ // TRANS: Client exception thrown when the maximum URL settings value is invalid in profile URL settings.
+ throw new ClientException(_('Invalid number for maximum URL length.'));
}
$maxnoticelength = $this->trimmed('maxnoticelength');
if (!Validate::number($maxnoticelength, array('min' => 0))) {
- throw new ClientException(_('Invalid number for max notice length.'));
+ // TRANS: Client exception thrown when the maximum notice length settings value is invalid in profile URL settings.
+ throw new ClientException(_('Invalid number for maximum notice length.'));
}
$user = common_current_user();
}
if (!$result) {
+ // TRANS: Server exception thrown in profile URL settings when preferences could not be saved.
throw new ServerException(_('Error saving user URL shortening preferences.'));
}
function showPageNotice()
{
- // TRANS: Page notice on "Auhtorize subscription" page.
+ // TRANS: Page notice on "Authorize subscription" page.
$this->element('p', null, _('Please check these details to make sure '.
'that you want to subscribe to this ' .
'user’s notices. If you didn’t just ask ' .
{
// TRANS: Accept message header from Authorise subscription page.
common_show_header(_('Subscription authorized'));
- // TRANS: Accept message text from Authorise subscription page.
$this->element('p', null,
+ // TRANS: Accept message text from Authorise subscription page.
_('The subscription has been authorized, but no '.
- 'callback URL was passed. Check with the site’s ' .
+ 'callback URL was passed. Check with the site\'s ' .
'instructions for details on how to authorize the ' .
'subscription. Your subscription token is:'));
$this->element('blockquote', 'token', $tok);
{
// TRANS: Reject message header from Authorise subscription page.
common_show_header(_('Subscription rejected'));
- // TRANS: Reject message from Authorise subscription page.
$this->element('p', null,
+ // TRANS: Reject message from Authorise subscription page.
_('The subscription has been rejected, but no '.
- 'callback URL was passed. Check with the site’s ' .
+ 'callback URL was passed. Check with the site\'s ' .
'instructions for details on how to fully reject ' .
'the subscription.'));
common_show_footer();
if (empty($member)) {
// TRANS: Exception thrown providing an invalid profile ID.
// TRANS: %s is the invalid profile ID.
- throw new Exception(sprintf(_("Profile ID %s is invalid."),$this->profile_id));
+ throw new Exception(sprintf(_('Profile ID %s is invalid.'),$this->profile_id));
}
return $member;
if (empty($group)) {
// TRANS: Exception thrown providing an invalid group ID.
// TRANS: %s is the invalid group ID.
- throw new Exception(sprintf(_("Group ID %s is invalid."),$this->group_id));
+ throw new Exception(sprintf(_('Group ID %s is invalid.'),$this->group_id));
}
return $group;
function getFancyName()
{
if ($this->fullname) {
- // TRANS: Full name of a profile or group followed by nickname in parens
+ // TRANS: Full name of a profile or group (%1$s) followed by nickname (%2$s) in parentheses.
return sprintf(_m('FANCYNAME','%1$s (%2$s)'), $this->fullname, $this->nickname);
} else {
return $this->nickname;
*
* @return mixed Notice or null
*/
-
function getCurrentNotice()
{
$notice = $this->getNotices(0, 1);
{
return Subscription::exists($this, $other);
}
-
+
/**
* Check if a pending subscription request is outstanding for this...
*
common_date_iso8601($this->created));
$act->time = strtotime($this->created);
- // TRANS: Activity tile when subscribing to another person.
- $act->title = _("Follow");
+ // TRANS: Activity title when subscribing to another person.
+ $act->title = _m('TITLE','Follow');
// TRANS: Notification given when one person starts following another.
// TRANS: %1$s is the subscriber, %2$s is the subscribed.
$act->content = sprintf(_('%1$s is now following %2$s.'),
*
* @return Subscription stream of subscriptions; use fetch() to iterate
*/
-
static function bySubscriber($subscriberId,
$offset = 0,
$limit = PROFILES_PER_PAGE)
*
* @return Subscription stream of subscriptions; use fetch() to iterate
*/
-
static function bySubscribed($subscribedId,
$offset = 0,
$limit = PROFILES_PER_PAGE)
*
* @return boolean success flag.
*/
-
function update($orig=null)
{
$result = parent::update($orig);
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
* @link http://status.net/
*/
-
class AccountProfileBlock extends ProfileBlock
{
protected $profile = null;
$this->out->elementStart('li', 'entity_edit');
$this->out->element('a', array('href' => common_local_url('profilesettings'),
// TRANS: Link title for link on user profile.
- 'title' => _('Edit profile settings')),
+ 'title' => _('Edit profile settings.')),
// TRANS: Link text for link on user profile.
- _('Edit'));
+ _m('BUTTON','Edit'));
$this->out->elementEnd('li');
} else { // someone else's page
$this->out->elementStart('li', 'entity_send-a-message');
$this->out->element('a', array('href' => common_local_url('newmessage', array('to' => $this->user->id)),
// TRANS: Link title for link on user profile.
- 'title' => _('Send a direct message to this user')),
+ 'title' => _('Send a direct message to this user.')),
// TRANS: Link text for link on user profile.
- _('Message'));
+ _m('BUTTON','Message'));
$this->out->elementEnd('li');
// nudge
$this->out->element('a', array('href' => $url,
'class' => 'entity_remote_subscribe'),
// TRANS: Link text for link that will subscribe to a remote profile.
- _('Subscribe'));
+ _m('BUTTON','Subscribe'));
}
-}
\ No newline at end of file
+}
*
* @see UnsubscribeForm
*/
-
class CancelSubscriptionForm extends Form
{
/**
* @param HTMLOutputter $out output channel
* @param Profile $profile being subscribed to
*/
-
function __construct($out=null, $profile=null)
{
parent::__construct($out);
*
* @return string ID of the form
*/
-
function id()
{
return 'subscription-cancel-' . $this->profile->id;
*
* @return string of the form class
*/
-
function formClass()
{
return 'form_unsubscribe ajax';
*
* @return string URL of the action
*/
-
function action()
{
return common_local_url('cancelsubscription',
*
* @return void
*/
-
function formActions()
{
- $this->out->submit('submit', _('Cancel sub request'));
+ // TRANS: Button text for form action to cancel a subscription request.
+ $this->out->submit('submit', _m('BUTTON','Cancel subscription request'));
}
}
}
/**
- * notify a user that one of their notices has been chosen as a 'fave'
+ * Notify a user that one of their notices has been chosen as a 'fave'
*
* Doesn't check that the user has an email address nor if they
* want to receive notification of faves. Maybe this happens higher
}
/**
- * notify a user that they have received an "attn:" message AKA "@-reply"
+ * Notify a user that they have received an "attn:" message AKA "@-reply"
*
* @param User $user The user who recevied the notice
* @param Notice $notice The notice that was sent
private function __construct()
{
}
-
+
public static function getInstance($id = '__default__')
{
if (empty(self::$_singleton)) {
}
return $result;
}
-
+
protected function _mapAction($action, $path)
{
if (!array_key_exists($action, $this->_actionToPath)) {
$this->_actionToPath[$action][] = $path;
return;
}
-
+
public function generate($values = array(), $qstring = array(), $anchor = '')
{
if (!array_key_exists('action', $values)) {
return parent::generate($values, $qstring, $anchor);
}
-
+
$action = $values['action'];
if (!array_key_exists($action, $this->_actionToPath)) {
return parent::generate($values, $qstring, $anchor);
}
-
+
$oldPaths = $this->paths;
$this->paths = $this->_actionToPath[$action];
$result = parent::generate($values, $qstring, $anchor);
/**
* Create a unique hashkey for the router.
- *
+ *
* The router's url map can change based on the version of the software
* you're running and the plugins that are enabled. To avoid having bad routes
* get stuck in the cache, the key includes a list of plugins and the software
* version.
- *
- * There can still be problems with a) differences in versions of the plugins and
+ *
+ * There can still be problems with a) differences in versions of the plugins and
* b) people running code between official versions, but these tend to be more
* sophisticated users who can grok what's going on and clear their caches.
- *
+ *
* @return string cache key string that should uniquely identify a router
*/
-
+
static function cacheKey()
{
$parts = array('router');
return Cache::codeKey(implode(':', $parts));
}
-
+
function initialize()
{
$m = StatusNet_URL_Mapper::getInstance();
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class SubGroupNav extends Menu
{
var $user = null;
*
* @param Action $action current action, used for output
*/
-
function __construct($action=null, $user=null)
{
parent::__construct($action);
*
* @return void
*/
-
function show()
{
$cur = common_current_user();
$this->out->menuItem(common_local_url('showstream', array('nickname' =>
$this->user->nickname)),
- _('Profile'),
+ // TRANS: Menu item in local navigation menu.
+ _m('MENU','Profile'),
(empty($profile)) ? $this->user->nickname : $profile->getBestName(),
$action == 'showstream',
'nav_profile');
$this->out->menuItem(common_local_url('subscriptions',
array('nickname' =>
$this->user->nickname)),
- _('Subscriptions'),
- sprintf(_('People %s subscribes to'),
+ // TRANS: Menu item in local navigation menu.
+ _m('MENU','Subscriptions'),
+ // TRANS: Menu item title in local navigation menu.
+ // TRANS: %s is a user nickname.
+ sprintf(_('People %s subscribes to.'),
$this->user->nickname),
$action == 'subscriptions',
'nav_subscriptions');
$this->out->menuItem(common_local_url('subscribers',
array('nickname' =>
$this->user->nickname)),
- _('Subscribers'),
- sprintf(_('People subscribed to %s'),
+ // TRANS: Menu item in local navigation menu.
+ _m('MENU','Subscribers'),
+ // TRANS: Menu item title in local navigation menu.
+ // TRANS: %s is a user nickname.
+ sprintf(_('People subscribed to %s.'),
$this->user->nickname),
$action == 'subscribers',
'nav_subscribers');
$this->out->menuItem(common_local_url('subqueue',
array('nickname' =>
$this->user->nickname)),
- sprintf(_('Pending (%d)'), $pending),
- sprintf(_('Approve pending subscription requests'),
+ // TRANS: Menu item in local navigation menu.
+ sprintf(_m('MENU','Pending (%d)'), $pending),
+ // TRANS: Menu item title in local navigation menu.
+ sprintf(_('Approve pending subscription requests.'),
$this->user->nickname),
$action == 'subqueueaction',
'nav_subscribers');
$this->out->menuItem(common_local_url('usergroups',
array('nickname' =>
$this->user->nickname)),
- _('Groups'),
- sprintf(_('Groups %s is a member of'),
+ // TRANS: Menu item in local navigation menu.
+ _m('MENU','Groups'),
+ // TRANS: Menu item title in local navigation menu.
+ // TRANS: %s is a user nickname.
+ sprintf(_('Groups %s is a member of.'),
$this->user->nickname),
$action == 'usergroups',
'nav_usergroups');
if (common_config('invite', 'enabled') && !is_null($cur) && $this->user->id === $cur->id) {
$this->out->menuItem(common_local_url('invite'),
- _('Invite'),
- sprintf(_('Invite friends and colleagues to join you on %s'),
+ // TRANS: Menu item in local navigation menu.
+ _m('MENU','Invite'),
+ // TRANS: Menu item title in local navigation menu.
+ // TRANS: %s is a user nickname.
+ sprintf(_('Invite friends and colleagues to join you on %s.'),
common_config('site', 'name')),
$action == 'invite',
'nav_invite');