forked from GNUsocial/gnu-social
[Favourite] Add backend support for favourite
This commit is contained in:
parent
b6fb0255da
commit
8a0418d8cf
69
plugins/Favourite/Favourite.php
Normal file
69
plugins/Favourite/Favourite.php
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// {{{ 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\Favourite;
|
||||||
|
|
||||||
|
use App\Core\DB\DB;
|
||||||
|
use App\Core\Event;
|
||||||
|
use App\Core\Form;
|
||||||
|
use function App\Core\I18n\_m;
|
||||||
|
use App\Core\Module;
|
||||||
|
use App\Entity\Favourite as Fave;
|
||||||
|
use App\Entity\Note;
|
||||||
|
use App\Util\Common;
|
||||||
|
use Symfony\Component\Form\Extension\Core\Type\HiddenType;
|
||||||
|
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
|
||||||
|
class Favourite extends Module
|
||||||
|
{
|
||||||
|
public function onAddNoteActions(Request $request, Note $note, array &$actions)
|
||||||
|
{
|
||||||
|
$opts = ['note_id' => $note->getId(), 'gsactor_id' => Common::ensureLoggedIn()->getActor()->getId()];
|
||||||
|
$is_set = DB::find('favourite', $opts) != null;
|
||||||
|
$form = Form::create([
|
||||||
|
['is_set', HiddenType::class, ['data' => $is_set ? '1' : '0']],
|
||||||
|
['note_id', HiddenType::class, ['data' => $note->getId()]],
|
||||||
|
['favourite', SubmitType::class, ['label' => _m('Favourite')]],
|
||||||
|
]);
|
||||||
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted()) {
|
||||||
|
$data = $form->getData();
|
||||||
|
var_dump($data);
|
||||||
|
|
||||||
|
$fave = DB::find('favourite', $opts);
|
||||||
|
if ($data['note_id'] == $note->getId() && $form->isValid()) {
|
||||||
|
// Loose comparison
|
||||||
|
if (!$data['is_set'] && ($fave == null)) {
|
||||||
|
DB::persist(Fave::create($opts));
|
||||||
|
DB::flush();
|
||||||
|
} else {
|
||||||
|
DB::remove($fave);
|
||||||
|
DB::flush();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// TODO display errors
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$actions[] = $form->createView();
|
||||||
|
return Event::next;
|
||||||
|
}
|
||||||
|
}
|
@ -49,6 +49,7 @@ class Extension extends AbstractExtension
|
|||||||
/** Twig function to output the 'active' class if the current route matches the given route */
|
/** Twig function to output the 'active' class if the current route matches the given route */
|
||||||
new TwigFunction('active', [Runtime::class, 'isCurrentRouteActive']),
|
new TwigFunction('active', [Runtime::class, 'isCurrentRouteActive']),
|
||||||
new TwigFunction('is_route', [Runtime::class, 'isCurrentRoute']),
|
new TwigFunction('is_route', [Runtime::class, 'isCurrentRoute']),
|
||||||
|
new TwigFunction('get_note_actions', [Runtime::class, 'getNoteActions']),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,8 @@
|
|||||||
|
|
||||||
namespace App\Twig;
|
namespace App\Twig;
|
||||||
|
|
||||||
|
use App\Core\Event;
|
||||||
|
use App\Entity\Note;
|
||||||
use App\Util\Formatting;
|
use App\Util\Formatting;
|
||||||
use Functional as F;
|
use Functional as F;
|
||||||
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||||
@ -56,6 +58,13 @@ class Runtime implements RuntimeExtensionInterface, EventSubscriberInterface
|
|||||||
return F\some($routes, F\partial_left([Formatting::class, 'startsWith'], $current_route)) ? $class : '';
|
return F\some($routes, F\partial_left([Formatting::class, 'startsWith'], $current_route)) ? $class : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getNoteActions(Note $note)
|
||||||
|
{
|
||||||
|
$actions = [];
|
||||||
|
Event::handle('add_note_actions', [$this->request, $note, &$actions]);
|
||||||
|
return $actions;
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
|
|
||||||
// Request is not a service, can't find a better way to get it
|
// Request is not a service, can't find a better way to get it
|
||||||
|
@ -14,21 +14,19 @@
|
|||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
<div class="note-actions">
|
<div class="note-actions">
|
||||||
|
{% for act in get_note_actions(note) %}
|
||||||
|
<div>
|
||||||
|
<svg class="icon icon-heart">
|
||||||
|
<use xlink:href="#icon-heart"></use>
|
||||||
|
</svg>
|
||||||
|
{{ form(act) }}
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
<a href="{{ path('note_reply', {'reply_to': note.getId()}) }}">
|
<a href="{{ path('note_reply', {'reply_to': note.getId()}) }}">
|
||||||
<svg class="icon icon-reply">
|
<svg class="icon icon-reply">
|
||||||
<use xlink:href="#icon-reply"></use>
|
<use xlink:href="#icon-reply"></use>
|
||||||
</svg>
|
</svg>
|
||||||
</a>
|
</a>
|
||||||
<a href="{{ path('note_recycle', {'repeat_of': note.getId()}) }}">
|
|
||||||
<svg class="icon icon-recycle">
|
|
||||||
<use xlink:href="#icon-recycle"></use>
|
|
||||||
</svg>
|
|
||||||
</a>
|
|
||||||
<a href="{{ path('note_reply', {'reply_to': note.getId()}) }}">
|
|
||||||
<svg class="icon icon-heart">
|
|
||||||
<use xlink:href="#icon-heart"></use>
|
|
||||||
</svg>
|
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="replies">
|
<div class="replies">
|
||||||
{% for reply in note.getReplies() %}
|
{% for reply in note.getReplies() %}
|
||||||
|
Loading…
Reference in New Issue
Block a user