forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			102 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * StatusNet - the distributed open-source microblogging tool
 | |
|  * Copyright (C) 2010, StatusNet, Inc.
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| if (!defined('GNUSOCIAL')) { exit(1); }
 | |
| 
 | |
| /**
 | |
|  * Some UI extras for now...
 | |
|  *
 | |
|  * @package ModPlusPlugin
 | |
|  * @maintainer Brion Vibber <brion@status.net>
 | |
|  */
 | |
| class ModPlusPlugin extends Plugin
 | |
| {
 | |
|     function onPluginVersion(array &$versions)
 | |
|     {
 | |
|         $versions[] = array('name' => 'ModPlus',
 | |
|                             'version' => GNUSOCIAL_VERSION,
 | |
|                             'author' => 'Brion Vibber',
 | |
|                             'homepage' => 'https://git.gnu.io/gnu/gnu-social/tree/master/plugins/ModPlus',
 | |
|                             'rawdescription' =>
 | |
|                             // TRANS: Plugin description.
 | |
|                             _m('UI extension for profile moderation actions.'));
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Load JS at runtime.
 | |
|      *
 | |
|      * @param Action $action
 | |
|      * @return boolean hook result
 | |
|      */
 | |
|     function onEndShowScripts(Action $action)
 | |
|     {
 | |
|         $action->script($this->path('js/modplus.js'));
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     public function onEndShowStylesheets(Action $action) {
 | |
|         $action->cssLink($this->path('css/modplus.css'));
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add per-profile info popup menu for author on notice lists.
 | |
|      *
 | |
|      * @param NoticeListItem $item
 | |
|      * @return boolean hook value
 | |
|      */
 | |
|     function onEndShowNoticeItemAuthor(Profile $profile, HTMLOutputter $out)
 | |
|     {
 | |
|         $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;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 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)
 | |
|     {
 | |
|         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);
 | |
|             $out->elementEnd('div');
 | |
|         }
 | |
|     }
 | |
| }
 |