gnu-social/plugins/Cover/Cover.php

101 lines
2.9 KiB
PHP
Raw Normal View History

<?php
declare(strict_types = 1);
// {{{ License
// 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/>.
// }}}
namespace Plugin\Cover;
use App\Core\DB;
use App\Core\Event;
use App\Core\Modules\Plugin;
use App\Core\Router;
use App\Util\Common;
use EventResult;
use Plugin\Cover\Controller as C;
use Symfony\Component\HttpFoundation\Request;
/**
* Cover plugin main class
*
* @package GNUsocial
* @category CoverPlugin
*
* @author Daniel Brandao <up201705812@fe.up.pt>
* @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
* @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
*/
class Cover extends Plugin
{
/**
* Map URLs to actions
*/
public function onAddRoute(Router $r): EventResult
{
$r->connect('settings_profile_cover', 'settings/cover', [Controller\Cover::class, 'coversettings']);
2020-11-28 07:25:37 +09:00
$r->connect('cover', '/cover', [Controller\Cover::class, 'cover']);
return Event::next;
}
/**
* @param SettingsTabsType $tabs
*/
public function onPopulateSettingsTabs(Request $request, string $section, &$tabs): EventResult
{
if ($section === 'profile') {
$tabs[] = [
'title' => 'Cover',
'desc' => 'Change your cover.',
'id' => 'settings-cover',
'controller' => C\Cover::coverSettings($request),
];
}
return Event::next;
}
/**
* Populate twig vars
*
* @return bool hook value; true means continue processing, false means stop.
*
* public function onStartTwigPopulateVars(array &$vars): \EventResult
* {
* if (Common::user() != null) {
* $cover = DB::find('cover', ['actor_id' => Common::user()->getId()]);
* if ($cover != null) {
* $vars['profile_extras'][] = ['name' => 'cover', 'vars' => ['img' => '/cover']];
* } else {
* $vars['profile_extras'][] = ['name' => 'cover', 'vars' => []];
* }
* }
* return Event::next;
* }*/
/**
* Output our dedicated stylesheet
*
* @param string[] $styles stylesheets path
*/
public function onStartShowStyles(array &$styles): EventResult
{
$styles[] = 'assets/css/cover.css';
return Event::next;
}
}