mirror of
https://github.com/flarum/core.git
synced 2025-08-06 08:27:42 +02:00
Use Frontend extender for embedding statistics in admin frontend
Refs flarum/core#1602, flarum/core#1608.
This commit is contained in:
@@ -11,14 +11,10 @@
|
|||||||
|
|
||||||
use Flarum\Extend;
|
use Flarum\Extend;
|
||||||
use Flarum\Statistics\Listener;
|
use Flarum\Statistics\Listener;
|
||||||
use Illuminate\Contracts\Events\Dispatcher;
|
|
||||||
|
|
||||||
return [
|
return [
|
||||||
(new Extend\Frontend('admin'))
|
(new Extend\Frontend('admin'))
|
||||||
->js(__DIR__.'/js/dist/admin.js')
|
->js(__DIR__.'/js/dist/admin.js')
|
||||||
->css(__DIR__.'/less/admin.less'),
|
->css(__DIR__.'/less/admin.less')
|
||||||
|
->content(Listener\AddStatisticsData::class),
|
||||||
function (Dispatcher $events) {
|
|
||||||
$events->subscribe(Listener\AddStatisticsData::class);
|
|
||||||
}
|
|
||||||
];
|
];
|
||||||
|
@@ -14,12 +14,12 @@ namespace Flarum\Statistics\Listener;
|
|||||||
use DateTime;
|
use DateTime;
|
||||||
use DateTimeZone;
|
use DateTimeZone;
|
||||||
use Flarum\Discussion\Discussion;
|
use Flarum\Discussion\Discussion;
|
||||||
|
use Flarum\Frontend\HtmlDocument;
|
||||||
use Flarum\Post\Post;
|
use Flarum\Post\Post;
|
||||||
use Flarum\User\User;
|
use Flarum\User\User;
|
||||||
use Flarum\Frontend\Event\Rendering;
|
use Flarum\Frontend\Event\Rendering;
|
||||||
use Flarum\Settings\SettingsRepositoryInterface;
|
use Flarum\Settings\SettingsRepositoryInterface;
|
||||||
use Illuminate\Database\Eloquent\Builder;
|
use Illuminate\Database\Eloquent\Builder;
|
||||||
use Illuminate\Contracts\Events\Dispatcher;
|
|
||||||
|
|
||||||
class AddStatisticsData
|
class AddStatisticsData
|
||||||
{
|
{
|
||||||
@@ -36,25 +36,12 @@ class AddStatisticsData
|
|||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function __invoke(HtmlDocument $view)
|
||||||
* @param Dispatcher $events
|
|
||||||
*/
|
|
||||||
public function subscribe(Dispatcher $events)
|
|
||||||
{
|
{
|
||||||
$events->listen(Rendering::class, [$this, 'addStatisticsData']);
|
$view->payload['statistics'] = array_merge(
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Rendering $event
|
|
||||||
*/
|
|
||||||
public function addStatisticsData(Rendering $event)
|
|
||||||
{
|
|
||||||
if ($event->isAdmin()) {
|
|
||||||
$event->view->setVariable('statistics', array_merge(
|
|
||||||
$this->getStatistics(),
|
$this->getStatistics(),
|
||||||
['timezoneOffset' => $this->getUserTimezone()->getOffset(new DateTime)]
|
['timezoneOffset' => $this->getUserTimezone()->getOffset(new DateTime)]
|
||||||
));
|
);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getStatistics()
|
private function getStatistics()
|
||||||
|
Reference in New Issue
Block a user