function onPluginVersion(&$versions)
{
$versions[] = array('name' => 'ModPlus',
- 'version' => STATUSNET_VERSION,
+ 'version' => GNUSOCIAL_VERSION,
'author' => 'Brion Vibber',
'homepage' => 'http://status.net/wiki/Plugin:ModPlus',
'rawdescription' =>
- _m('UI extensions for profile moderation actions.'));
+ // TRANS: Plugin description.
+ _m('UI extension for profile moderation actions.'));
return true;
}
/**
- * Load JS at runtime if we're logged in.
+ * Load JS at runtime.
*
* @param Action $action
* @return boolean hook result
*/
- function onEndShowScripts($action)
+ function onEndShowScripts(Action $action)
{
- $user = common_current_user();
- if ($user) {
- $action->script('plugins/ModPlus/modplus.js');
- }
+ $action->script($this->path('js/modplus.js'));
return true;
}
- function onEndShowStatusNetStyles($action) {
- $action->cssLink('plugins/ModPlus/modplus.css');
+ public function onEndShowStylesheets(Action $action) {
+ $action->cssLink($this->path('css/modplus.css'));
return true;
}
/**
- * Autoloader
+ * Add ModPlus-related paths to the router table
*
- * Loads our classes if they're requested.
+ * Hook for RouterInitialized event.
*
- * @param string $cls Class requested
+ * @param URLMapper $m URL mapper
*
* @return boolean hook return
*/
- function onAutoload($cls)
+ public function onStartInitializeRouter(URLMapper $m)
{
- switch ($cls)
- {
- case 'RemoteprofileAction':
- case 'RemoteProfileAction':
- require_once dirname(__FILE__) . '/remoteprofileaction.php';
- return false;
- default:
- return true;
- }
+ $m->connect('user/remote/:id',
+ array('action' => 'remoteprofile'),
+ array('id' => '[\d]+'));
+
+ return true;
}
/**
- * Add OpenID-related paths to the router table
- *
- * Hook for RouterInitialized event.
- *
- * @param Net_URL_Mapper $m URL mapper
+ * Add per-profile info popup menu for author on notice lists.
*
- * @return boolean hook return
+ * @param NoticeListItem $item
+ * @return boolean hook value
*/
- function onStartInitializeRouter($m)
+ function onEndShowNoticeItemAuthor(Profile $profile, HTMLOutputter $out)
{
- $m->connect('user/remote/:id',
- array('action' => 'remoteprofile'),
- array('id' => '[\d]+'));
+ $this->showProfileOptions($out, $profile);
+ return true;
+ }
+ /**
+ * Add per-profile info popup menu on profile lists.
+ *
+ * @param ProfileListItem $item
+ */
+ function onStartProfileListItemProfile($item)
+ {
+ $this->showProfileOptions($item->out, $item->profile->getProfile());
return true;
}
- function onStartShowNoticeItem($item)
+ /**
+ * Build common remote-profile options structure.
+ * Currently only adds output for remote profiles, nothing for local users.
+ *
+ * @param HTMLOutputter $out
+ * @param Profile $profile
+ */
+ protected function showProfileOptions(HTMLOutputter $out, Profile $profile)
{
- $profile = $item->profile;
- $isRemote = !(User::staticGet('id', $profile->id));
- if ($isRemote) {
+ if (!$profile->isGroup() && !$profile->isLocal()) {
$target = common_local_url('remoteprofile', array('id' => $profile->id));
+ // TRANS: Label for access to remote profile options.
$label = _m('Remote profile options...');
- $item->out->elementStart('div', 'remote-profile-options');
- $item->out->element('a', array('href' => $target), $label);
- $item->out->elementEnd('div');
+ $out->elementStart('div', 'remote-profile-options');
+ $out->element('a', array('href' => $target), $label);
+ $out->elementEnd('div');
}
}
}