mirror of
https://github.com/flarum/core.git
synced 2025-07-17 06:41:21 +02:00
Use new extenders (#26)
This commit is contained in:
@@ -7,11 +7,11 @@
|
|||||||
* LICENSE file that was distributed with this source code.
|
* LICENSE file that was distributed with this source code.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Flarum\Api\Event\Serializing;
|
|
||||||
use Flarum\Api\Serializer\BasicDiscussionSerializer;
|
use Flarum\Api\Serializer\BasicDiscussionSerializer;
|
||||||
|
use Flarum\Api\Serializer\DiscussionSerializer;
|
||||||
|
use Flarum\Discussion\Discussion;
|
||||||
use Flarum\Discussion\Event\Saving;
|
use Flarum\Discussion\Event\Saving;
|
||||||
use Flarum\Event\ConfigureDiscussionGambits;
|
use Flarum\Event\ConfigureDiscussionGambits;
|
||||||
use Flarum\Event\ConfigurePostTypes;
|
|
||||||
use Flarum\Extend;
|
use Flarum\Extend;
|
||||||
use Flarum\Lock\Access;
|
use Flarum\Lock\Access;
|
||||||
use Flarum\Lock\Event\DiscussionWasLocked;
|
use Flarum\Lock\Event\DiscussionWasLocked;
|
||||||
@@ -35,19 +35,26 @@ return [
|
|||||||
(new Extend\Notification())
|
(new Extend\Notification())
|
||||||
->type(DiscussionLockedBlueprint::class, BasicDiscussionSerializer::class, ['alert']),
|
->type(DiscussionLockedBlueprint::class, BasicDiscussionSerializer::class, ['alert']),
|
||||||
|
|
||||||
function (Dispatcher $events) {
|
(new Extend\ApiSerializer(DiscussionSerializer::class))
|
||||||
$events->listen(ConfigureDiscussionGambits::class, function (ConfigureDiscussionGambits $event) {
|
->attribute('isLocked', function (DiscussionSerializer $serializer, Discussion $discussion) {
|
||||||
|
return (bool) $discussion->is_locked;
|
||||||
|
})
|
||||||
|
->attribute('canLock', function (DiscussionSerializer $serializer, Discussion $discussion) {
|
||||||
|
return (bool) $serializer->getActor()->can('lock', $discussion);
|
||||||
|
}),
|
||||||
|
|
||||||
|
(new Extend\Post())
|
||||||
|
->type(DiscussionLockedPost::class),
|
||||||
|
|
||||||
|
(new Extend\Event())
|
||||||
|
->listen(ConfigureDiscussionGambits::class, function (ConfigureDiscussionGambits $event) {
|
||||||
$event->gambits->add(LockedGambit::class);
|
$event->gambits->add(LockedGambit::class);
|
||||||
});
|
})
|
||||||
$events->listen(Serializing::class, Listener\AddDiscussionLockedAttributes::class);
|
->listen(Saving::class, Listener\SaveLockedToDatabase::class)
|
||||||
$events->listen(Saving::class, Listener\SaveLockedToDatabase::class);
|
->listen(DiscussionWasLocked::class, Listener\CreatePostWhenDiscussionIsLocked::class)
|
||||||
|
->listen(DiscussionWasUnlocked::class, Listener\CreatePostWhenDiscussionIsUnlocked::class),
|
||||||
$events->listen(ConfigurePostTypes::class, function (ConfigurePostTypes $event) {
|
|
||||||
$event->add(DiscussionLockedPost::class);
|
|
||||||
});
|
|
||||||
$events->listen(DiscussionWasLocked::class, Listener\CreatePostWhenDiscussionIsLocked::class);
|
|
||||||
$events->listen(DiscussionWasUnlocked::class, Listener\CreatePostWhenDiscussionIsUnlocked::class);
|
|
||||||
|
|
||||||
|
function (Dispatcher $events) {
|
||||||
$events->subscribe(Access\DiscussionPolicy::class);
|
$events->subscribe(Access\DiscussionPolicy::class);
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
@@ -1,24 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This file is part of Flarum.
|
|
||||||
*
|
|
||||||
* For detailed copyright and license information, please view the
|
|
||||||
* LICENSE file that was distributed with this source code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace Flarum\Lock\Listener;
|
|
||||||
|
|
||||||
use Flarum\Api\Event\Serializing;
|
|
||||||
use Flarum\Api\Serializer\DiscussionSerializer;
|
|
||||||
|
|
||||||
class AddDiscussionLockedAttributes
|
|
||||||
{
|
|
||||||
public function handle(Serializing $event)
|
|
||||||
{
|
|
||||||
if ($event->isSerializer(DiscussionSerializer::class)) {
|
|
||||||
$event->attributes['isLocked'] = (bool) $event->model->is_locked;
|
|
||||||
$event->attributes['canLock'] = (bool) $event->actor->can('lock', $event->model);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user