mirror of
https://github.com/friendica/friendica
synced 2025-05-18 15:04:10 +02:00
Create events for networt_tabs and network_content_init hooks
This commit is contained in:
parent
584e7e05b0
commit
a34a93c0b9
5 changed files with 78 additions and 9 deletions
|
@ -54,6 +54,8 @@ final class HookEventBridge
|
||||||
ArrayFilterEvent::PREPARE_POST_END => 'prepare_body_final',
|
ArrayFilterEvent::PREPARE_POST_END => 'prepare_body_final',
|
||||||
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'photo_upload_form',
|
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'photo_upload_form',
|
||||||
ArrayFilterEvent::NETWORK_TO_NAME => 'network_to_name',
|
ArrayFilterEvent::NETWORK_TO_NAME => 'network_to_name',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_START => 'network_content_init',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_TABS => 'network_tabs',
|
||||||
ArrayFilterEvent::PARSE_LINK => 'parse_link',
|
ArrayFilterEvent::PARSE_LINK => 'parse_link',
|
||||||
ArrayFilterEvent::CONVERSATION_START => 'conversation_start',
|
ArrayFilterEvent::CONVERSATION_START => 'conversation_start',
|
||||||
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'item_by_link',
|
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'item_by_link',
|
||||||
|
@ -135,6 +137,8 @@ final class HookEventBridge
|
||||||
ArrayFilterEvent::PREPARE_POST_END => 'onArrayFilterEvent',
|
ArrayFilterEvent::PREPARE_POST_END => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'onArrayFilterEvent',
|
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::NETWORK_TO_NAME => 'onArrayFilterEvent',
|
ArrayFilterEvent::NETWORK_TO_NAME => 'onArrayFilterEvent',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_START => 'onArrayFilterEvent',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_TABS => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::PARSE_LINK => 'onArrayFilterEvent',
|
ArrayFilterEvent::PARSE_LINK => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::CONVERSATION_START => 'onArrayFilterEvent',
|
ArrayFilterEvent::CONVERSATION_START => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'onArrayFilterEvent',
|
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'onArrayFilterEvent',
|
||||||
|
|
|
@ -58,6 +58,10 @@ final class ArrayFilterEvent extends Event
|
||||||
|
|
||||||
public const NETWORK_TO_NAME = 'friendica.data.network_to_name';
|
public const NETWORK_TO_NAME = 'friendica.data.network_to_name';
|
||||||
|
|
||||||
|
public const NETWORK_CONTENT_START = 'friendica.data.network_content_start';
|
||||||
|
|
||||||
|
public const NETWORK_CONTENT_TABS = 'friendica.data.network_content_tabs';
|
||||||
|
|
||||||
public const PARSE_LINK = 'friendica.data.parse_link';
|
public const PARSE_LINK = 'friendica.data.parse_link';
|
||||||
|
|
||||||
public const CONVERSATION_START = 'friendica.data.conversation_start';
|
public const CONVERSATION_START = 'friendica.data.conversation_start';
|
||||||
|
|
|
@ -39,6 +39,7 @@ use Friendica\Core\Session\Capability\IHandleUserSessions;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Database\Database;
|
use Friendica\Database\Database;
|
||||||
|
use Friendica\Event\ArrayFilterEvent;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Model\Contact;
|
||||||
use Friendica\Model\Circle;
|
use Friendica\Model\Circle;
|
||||||
use Friendica\Model\Post;
|
use Friendica\Model\Post;
|
||||||
|
@ -49,6 +50,7 @@ use Friendica\Network\HTTPException;
|
||||||
use Friendica\Navigation\SystemMessages;
|
use Friendica\Navigation\SystemMessages;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
use Friendica\Util\Profiler;
|
use Friendica\Util\Profiler;
|
||||||
|
use Psr\EventDispatcher\EventDispatcherInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
class Network extends Timeline
|
class Network extends Timeline
|
||||||
|
@ -90,12 +92,55 @@ class Network extends Timeline
|
||||||
protected $community;
|
protected $community;
|
||||||
/** @var NetworkFactory */
|
/** @var NetworkFactory */
|
||||||
protected $networkFactory;
|
protected $networkFactory;
|
||||||
|
private EventDispatcherInterface $eventDispatcher;
|
||||||
|
|
||||||
public function __construct(UserDefinedChannelFactory $userDefinedChannel, NetworkFactory $network, CommunityFactory $community, ChannelFactory $channelFactory, UserDefinedChannel $channel, AppHelper $appHelper, TimelineFactory $timeline, SystemMessages $systemMessages, Mode $mode, Conversation $conversation, Page $page, IHandleUserSessions $session, Database $database, IManagePersonalConfigValues $pConfig, IManageConfigValues $config, ICanCache $cache, L10n $l10n, BaseURL $baseUrl, Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, array $server, array $parameters = [])
|
public function __construct(
|
||||||
{
|
UserDefinedChannelFactory $userDefinedChannel,
|
||||||
parent::__construct($channel, $mode, $session, $database, $pConfig, $config, $cache, $l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
|
NetworkFactory $network,
|
||||||
|
CommunityFactory $community,
|
||||||
|
ChannelFactory $channelFactory,
|
||||||
|
UserDefinedChannel $channel,
|
||||||
|
AppHelper $appHelper,
|
||||||
|
EventDispatcherInterface $eventDispatcher,
|
||||||
|
TimelineFactory $timeline,
|
||||||
|
SystemMessages $systemMessages,
|
||||||
|
Mode $mode,
|
||||||
|
Conversation $conversation,
|
||||||
|
Page $page,
|
||||||
|
IHandleUserSessions $session,
|
||||||
|
Database $database,
|
||||||
|
IManagePersonalConfigValues $pConfig,
|
||||||
|
IManageConfigValues $config,
|
||||||
|
ICanCache $cache,
|
||||||
|
L10n $l10n,
|
||||||
|
BaseURL $baseUrl,
|
||||||
|
Arguments $args,
|
||||||
|
LoggerInterface $logger,
|
||||||
|
Profiler $profiler,
|
||||||
|
Response $response,
|
||||||
|
array $server,
|
||||||
|
array $parameters = []
|
||||||
|
) {
|
||||||
|
parent::__construct(
|
||||||
|
$channel,
|
||||||
|
$mode,
|
||||||
|
$session,
|
||||||
|
$database,
|
||||||
|
$pConfig,
|
||||||
|
$config,
|
||||||
|
$cache,
|
||||||
|
$l10n,
|
||||||
|
$baseUrl,
|
||||||
|
$args,
|
||||||
|
$logger,
|
||||||
|
$profiler,
|
||||||
|
$response,
|
||||||
|
$server,
|
||||||
|
$parameters,
|
||||||
|
);
|
||||||
|
|
||||||
$this->appHelper = $appHelper;
|
$this->appHelper = $appHelper;
|
||||||
|
$this->eventDispatcher = $eventDispatcher;
|
||||||
$this->timeline = $timeline;
|
$this->timeline = $timeline;
|
||||||
$this->systemMessages = $systemMessages;
|
$this->systemMessages = $systemMessages;
|
||||||
$this->conversation = $conversation;
|
$this->conversation = $conversation;
|
||||||
|
@ -116,8 +161,13 @@ class Network extends Timeline
|
||||||
|
|
||||||
$module = 'network';
|
$module = 'network';
|
||||||
|
|
||||||
$arr = ['query' => $this->args->getQueryString()];
|
$hook_data = [
|
||||||
Hook::callAll('network_content_init', $arr);
|
'query' => $this->args->getQueryString(),
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->eventDispatcher->dispatch(
|
||||||
|
new ArrayFilterEvent(ArrayFilterEvent::NETWORK_CONTENT_START, $hook_data)
|
||||||
|
);
|
||||||
|
|
||||||
$o = '';
|
$o = '';
|
||||||
|
|
||||||
|
@ -275,19 +325,24 @@ class Network extends Timeline
|
||||||
$tabs = array_merge($tabs, $this->getTabArray($this->community->getTimelines(true), 'network', 'channel'));
|
$tabs = array_merge($tabs, $this->getTabArray($this->community->getTimelines(true), 'network', 'channel'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$arr = ['tabs' => $tabs];
|
$hook_data = [
|
||||||
Hook::callAll('network_tabs', $arr);
|
'tabs' => $tabs,
|
||||||
|
];
|
||||||
|
|
||||||
|
$hook_data = $this->eventDispatcher->dispatch(
|
||||||
|
new ArrayFilterEvent(ArrayFilterEvent::NETWORK_CONTENT_TABS, $hook_data)
|
||||||
|
)->getArray();
|
||||||
|
|
||||||
if (!empty($network_timelines)) {
|
if (!empty($network_timelines)) {
|
||||||
$tabs = [];
|
$tabs = [];
|
||||||
|
|
||||||
foreach ($arr['tabs'] as $tab) {
|
foreach ($hook_data['tabs'] as $tab) {
|
||||||
if (in_array($tab['code'], $network_timelines)) {
|
if (in_array($tab['code'], $network_timelines)) {
|
||||||
$tabs[] = $tab;
|
$tabs[] = $tab;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$tabs = $arr['tabs'];
|
$tabs = $hook_data['tabs'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
|
$tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
|
||||||
|
|
|
@ -43,6 +43,8 @@ class HookEventBridgeTest extends TestCase
|
||||||
ArrayFilterEvent::PREPARE_POST_END => 'onArrayFilterEvent',
|
ArrayFilterEvent::PREPARE_POST_END => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'onArrayFilterEvent',
|
ArrayFilterEvent::PHOTO_UPLOAD_FORM => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::NETWORK_TO_NAME => 'onArrayFilterEvent',
|
ArrayFilterEvent::NETWORK_TO_NAME => 'onArrayFilterEvent',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_START => 'onArrayFilterEvent',
|
||||||
|
ArrayFilterEvent::NETWORK_CONTENT_TABS => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::PARSE_LINK => 'onArrayFilterEvent',
|
ArrayFilterEvent::PARSE_LINK => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::CONVERSATION_START => 'onArrayFilterEvent',
|
ArrayFilterEvent::CONVERSATION_START => 'onArrayFilterEvent',
|
||||||
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'onArrayFilterEvent',
|
ArrayFilterEvent::FETCH_ITEM_BY_LINK => 'onArrayFilterEvent',
|
||||||
|
@ -465,6 +467,8 @@ class HookEventBridgeTest extends TestCase
|
||||||
[ArrayFilterEvent::PREPARE_POST_END, 'prepare_body_final'],
|
[ArrayFilterEvent::PREPARE_POST_END, 'prepare_body_final'],
|
||||||
[ArrayFilterEvent::PHOTO_UPLOAD_FORM, 'photo_upload_form'],
|
[ArrayFilterEvent::PHOTO_UPLOAD_FORM, 'photo_upload_form'],
|
||||||
[ArrayFilterEvent::NETWORK_TO_NAME, 'network_to_name'],
|
[ArrayFilterEvent::NETWORK_TO_NAME, 'network_to_name'],
|
||||||
|
[ArrayFilterEvent::NETWORK_CONTENT_START, 'network_content_init'],
|
||||||
|
[ArrayFilterEvent::NETWORK_CONTENT_TABS, 'network_tabs'],
|
||||||
[ArrayFilterEvent::PARSE_LINK, 'parse_link'],
|
[ArrayFilterEvent::PARSE_LINK, 'parse_link'],
|
||||||
[ArrayFilterEvent::CONVERSATION_START, 'conversation_start'],
|
[ArrayFilterEvent::CONVERSATION_START, 'conversation_start'],
|
||||||
[ArrayFilterEvent::FETCH_ITEM_BY_LINK, 'item_by_link'],
|
[ArrayFilterEvent::FETCH_ITEM_BY_LINK, 'item_by_link'],
|
||||||
|
|
|
@ -40,6 +40,8 @@ class ArrayFilterEventTest extends TestCase
|
||||||
[ArrayFilterEvent::PREPARE_POST_END, 'friendica.data.prepare_post_end'],
|
[ArrayFilterEvent::PREPARE_POST_END, 'friendica.data.prepare_post_end'],
|
||||||
[ArrayFilterEvent::PHOTO_UPLOAD_FORM, 'friendica.data.photo_upload_form'],
|
[ArrayFilterEvent::PHOTO_UPLOAD_FORM, 'friendica.data.photo_upload_form'],
|
||||||
[ArrayFilterEvent::NETWORK_TO_NAME, 'friendica.data.network_to_name'],
|
[ArrayFilterEvent::NETWORK_TO_NAME, 'friendica.data.network_to_name'],
|
||||||
|
[ArrayFilterEvent::NETWORK_CONTENT_START, 'friendica.data.network_content_start'],
|
||||||
|
[ArrayFilterEvent::NETWORK_CONTENT_TABS, 'friendica.data.network_content_tabs'],
|
||||||
[ArrayFilterEvent::PARSE_LINK, 'friendica.data.parse_link'],
|
[ArrayFilterEvent::PARSE_LINK, 'friendica.data.parse_link'],
|
||||||
[ArrayFilterEvent::CONVERSATION_START, 'friendica.data.conversation_start'],
|
[ArrayFilterEvent::CONVERSATION_START, 'friendica.data.conversation_start'],
|
||||||
[ArrayFilterEvent::FETCH_ITEM_BY_LINK, 'friendica.data.fetch_item_by_link'],
|
[ArrayFilterEvent::FETCH_ITEM_BY_LINK, 'friendica.data.fetch_item_by_link'],
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue