Enable user defined channels upon adding/editing

This commit is contained in:
Michael 2024-04-15 20:14:40 +00:00
parent ac195c7061
commit 652802f758

View file

@ -26,6 +26,7 @@ use Friendica\Content\Conversation\Factory;
use Friendica\Content\Conversation\Repository\UserDefinedChannel; use Friendica\Content\Conversation\Repository\UserDefinedChannel;
use Friendica\Core\Config\Capability\IManageConfigValues; use Friendica\Core\Config\Capability\IManageConfigValues;
use Friendica\Core\L10n; use Friendica\Core\L10n;
use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues;
use Friendica\Core\Renderer; use Friendica\Core\Renderer;
use Friendica\Core\Session\Capability\IHandleUserSessions; use Friendica\Core\Session\Capability\IHandleUserSessions;
use Friendica\Model\Circle; use Friendica\Model\Circle;
@ -41,18 +42,21 @@ class Channels extends BaseSettings
{ {
/** @var UserDefinedChannel */ /** @var UserDefinedChannel */
private $channel; private $channel;
/** @var IManagePersonalConfigValues */
private $pConfig;
/** @var Factory\UserDefinedChannel */ /** @var Factory\UserDefinedChannel */
private $userDefinedChannel; private $userDefinedChannel;
/** @var IManageConfigValues */ /** @var IManageConfigValues */
private $config; private $config;
public function __construct(Factory\UserDefinedChannel $userDefinedChannel, UserDefinedChannel $channel, App\Page $page, IHandleUserSessions $session, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, IManageConfigValues $config, array $server, array $parameters = []) public function __construct(Factory\UserDefinedChannel $userDefinedChannel, UserDefinedChannel $channel, App\Page $page, IHandleUserSessions $session, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, IManagePersonalConfigValues $pConfig, IManageConfigValues $config, array $server, array $parameters = [])
{ {
parent::__construct($session, $page, $l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters); parent::__construct($session, $page, $l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
$this->userDefinedChannel = $userDefinedChannel; $this->userDefinedChannel = $userDefinedChannel;
$this->channel = $channel; $this->channel = $channel;
$this->config = $config; $this->config = $config;
$this->pConfig = $pConfig;
} }
protected function post(array $request = []) protected function post(array $request = [])
@ -91,6 +95,7 @@ class Channels extends BaseSettings
]); ]);
$saved = $this->channel->save($channel); $saved = $this->channel->save($channel);
$this->logger->debug('New channel added', ['saved' => $saved]); $this->logger->debug('New channel added', ['saved' => $saved]);
$this->enableTimeline($uid, $saved->code);
return; return;
} }
@ -123,6 +128,7 @@ class Channels extends BaseSettings
]); ]);
$saved = $this->channel->save($channel); $saved = $this->channel->save($channel);
$this->logger->debug('Save channel', ['id' => $id, 'saved' => $saved]); $this->logger->debug('Save channel', ['id' => $id, 'saved' => $saved]);
$this->enableTimeline($uid, $id);
} }
} }
@ -232,4 +238,21 @@ class Channels extends BaseSettings
'$form_security_token' => self::getFormSecurityToken('settings_channels'), '$form_security_token' => self::getFormSecurityToken('settings_channels'),
]); ]);
} }
private function enableTimeline(int $uid, int $id)
{
$bookmarked_timelines = $this->pConfig->get($uid, 'system', 'network_timelines');
$enabled_timelines = $this->pConfig->get($uid, 'system', 'enabled_timelines');
if (empty($enabled_timelines) || empty($bookmarked_timelines)) {
return;
}
if (in_array($id, $enabled_timelines) || in_array($id, $bookmarked_timelines)) {
return;
}
$enabled_timelines[] = $id;
$this->pConfig->set($uid, 'system', 'enabled_timelines', $enabled_timelines);
}
} }