<?php // This file is part of GNU social - https://www.gnu.org/software/social // // GNU social 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. // // GNU social 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 GNU social. If not, see <http://www.gnu.org/licenses/>. /** * The GroupFavorited plugin adds a menu item for popular notices in groups. * * @package GroupFavoritedPlugin * @author Brion Vibber <brion@status.net> * @author Diogo Cordeiro <diogo@fc.up.pt> * @copyright 2010-2019 Free Software Foundation, Inc http://www.fsf.org * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ defined('GNUSOCIAL') || die(); class GroupFavoritedPlugin extends Plugin { const PLUGIN_VERSION = '2.0.1'; /** * Hook for RouterInitialized event. * * @param URLMapper $m path-to-action mapper * @return boolean hook return * @throws Exception */ public function onRouterInitialized(URLMapper $m) { $m->connect( 'group/:nickname/favorited', ['action' => 'groupfavorited'], ['nickname' => '[a-zA-Z0-9]+'] ); return true; } public function onEndGroupActionsList(GroupProfileBlock $nav, User_group $group) { $nav->out->elementStart('li', 'entity_popular'); $nav->out->element( 'a', [ 'href' => common_local_url( 'groupfavorited', ['nickname' => $group->nickname] ), // TRANS: Tooltip for menu item in the group navigation page. // TRANS: %s is the nickname of the group. 'title' => sprintf(_m('TOOLTIP', 'Popular notices in %s group'), $group->nickname) ], // TRANS: Menu item in the group navigation page. _m('MENU', 'Popular') ); $nav->out->elementEnd('li'); } /** * Provide plugin version information. * * This data is used when showing the version page. * * @param array &$versions array of version data arrays; see EVENTS.txt * * @return bool hook value */ public function onPluginVersion(array &$versions): bool { $url = 'https://git.gnu.io/gnu/gnu-social/tree/master/plugins/GroupFavorited'; $versions[] = ['name' => 'GroupFavorited', 'version' => self::PLUGIN_VERSION, 'author' => 'Brion Vibber', 'homepage' => $url, 'rawdescription' => // TRANS: Plugin description. _m('This plugin adds a menu item for popular notices in groups.') ]; return true; } }