* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-if (!defined('STATUSNET')) {
- exit(1);
-}
+if (!defined('GNUSOCIAL')) { exit(1); }
/**
* Some UI extras for now...
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($this->path('modplus.js'));
- }
- return true;
- }
-
- function onEndShowStatusNetStyles($action) {
- $action->cssLink($this->path('modplus.css'));
+ $action->script($this->path('js/modplus.js'));
return true;
}
- /**
- * Autoloader
- *
- * Loads our classes if they're requested.
- *
- * @param string $cls Class requested
- *
- * @return boolean hook return
- */
- function onAutoload($cls)
- {
- switch ($cls)
- {
- case 'RemoteprofileAction':
- case 'RemoteProfileAction':
- require_once dirname(__FILE__) . '/remoteprofileaction.php';
- return false;
- default:
- return true;
- }
- }
-
- /**
- * Add ModPlus-related paths to the router table
- *
- * Hook for RouterInitialized event.
- *
- * @param Net_URL_Mapper $m URL mapper
- *
- * @return boolean hook return
- */
- function onStartInitializeRouter($m)
- {
- $m->connect('user/remote/:id',
- array('action' => 'remoteprofile'),
- array('id' => '[\d]+'));
-
+ public function onEndShowStylesheets(Action $action) {
+ $action->cssLink($this->path('css/modplus.css'));
return true;
}
* @param NoticeListItem $item
* @return boolean hook value
*/
- function onStartShowNoticeItem($item)
+ function onEndShowNoticeItemAuthor(Profile $profile, HTMLOutputter $out)
{
- $this->showProfileOptions($item->out, $item->profile);
+ $this->showProfileOptions($out, $profile);
return true;
}
*/
function onStartProfileListItemProfile($item)
{
- $this->showProfileOptions($item->out, $item->profile);
+ $this->showProfileOptions($item->out, $item->profile->getProfile());
return true;
}
*/
protected function showProfileOptions(HTMLOutputter $out, Profile $profile)
{
- $isRemote = !(User::staticGet('id', $profile->id));
- if ($isRemote) {
- $target = common_local_url('remoteprofile', array('id' => $profile->id));
+ if (!$profile->isGroup() && !$profile->isLocal()) {
+ $target = common_local_url('userbyid', array('id' => $profile->getID()));
+ // TRANS: Label for access to remote profile options.
$label = _m('Remote profile options...');
$out->elementStart('div', 'remote-profile-options');
$out->element('a', array('href' => $target), $label);