2021-09-27 10:39:58 +01:00
|
|
|
<?php
|
|
|
|
|
2021-10-10 09:26:18 +01:00
|
|
|
declare(strict_types = 1);
|
|
|
|
|
2021-09-27 10:39:58 +01:00
|
|
|
// {{{ 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 Component\Search;
|
|
|
|
|
|
|
|
use App\Core\Event;
|
|
|
|
use App\Core\Form;
|
2021-10-10 09:26:18 +01:00
|
|
|
use function App\Core\I18n\_m;
|
2021-09-27 10:39:58 +01:00
|
|
|
use App\Core\Modules\Component;
|
2022-04-03 21:40:32 +01:00
|
|
|
use App\Core\Router;
|
2021-12-11 10:48:08 +00:00
|
|
|
use App\Util\Common;
|
2022-02-26 14:45:38 +00:00
|
|
|
use App\Util\Exception\ClientException;
|
2021-09-27 10:39:58 +01:00
|
|
|
use App\Util\Exception\RedirectException;
|
2022-01-17 16:32:41 +00:00
|
|
|
use App\Util\Formatting;
|
2022-04-03 21:40:32 +01:00
|
|
|
use EventResult;
|
2021-09-27 10:39:58 +01:00
|
|
|
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
|
|
|
use Symfony\Component\Form\Extension\Core\Type\TextType;
|
2021-12-10 13:52:18 +00:00
|
|
|
use Symfony\Component\Form\FormView;
|
2021-12-11 10:48:08 +00:00
|
|
|
use Symfony\Component\Form\SubmitButton;
|
2021-09-27 10:39:58 +01:00
|
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
|
|
|
|
|
|
class Search extends Component
|
|
|
|
{
|
2022-04-03 21:40:32 +01:00
|
|
|
public function onAddRoute(Router $r): EventResult
|
2021-09-27 10:39:58 +01:00
|
|
|
{
|
|
|
|
$r->connect('search', '/search', Controller\Search::class);
|
2022-04-03 21:40:32 +01:00
|
|
|
return EventResult::next;
|
2021-09-27 10:39:58 +01:00
|
|
|
}
|
|
|
|
|
2021-12-16 10:52:06 +00:00
|
|
|
/**
|
|
|
|
* Helper function for generating and processing the search form, so it can be embedded in
|
|
|
|
* multiple places. Can be provided with a $query, which will prefill the query field. If
|
|
|
|
* $add_subscribe, allow the user to add the current query to their left panel
|
|
|
|
*/
|
2021-12-11 10:48:08 +00:00
|
|
|
public static function searchForm(Request $request, ?string $query = null, bool $add_subscribe = false): FormView
|
2021-09-27 10:39:58 +01:00
|
|
|
{
|
2021-12-11 10:48:08 +00:00
|
|
|
$actor = Common::actor();
|
|
|
|
if (\is_null($actor)) {
|
|
|
|
$add_subscribe = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$form_definition = [
|
2021-12-10 13:40:42 +00:00
|
|
|
['search_query', TextType::class, [
|
|
|
|
'attr' => ['placeholder' => _m('Input desired query...'), 'value' => $query],
|
2021-10-04 12:17:14 +01:00
|
|
|
]],
|
2021-12-11 10:48:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
if ($add_subscribe) {
|
|
|
|
$form_definition[] = [
|
2022-02-16 21:17:13 +00:00
|
|
|
'title', TextType::class,
|
|
|
|
[
|
|
|
|
'label' => _m('Subscribe to search query'),
|
|
|
|
'help' => _m('By subscribing to a search query, a new feed link will be added to left panel\'s feed navigation menu'),
|
|
|
|
'required' => false,
|
|
|
|
'attr' => [
|
|
|
|
'title' => _m('Title for this new feed in your left panel'),
|
|
|
|
'placeholder' => _m('Input desired title...'),
|
|
|
|
],
|
|
|
|
],
|
2021-12-11 10:48:08 +00:00
|
|
|
];
|
|
|
|
$form_definition[] = [
|
|
|
|
'subscribe_to_search',
|
|
|
|
SubmitType::class,
|
2021-12-10 13:52:18 +00:00
|
|
|
[
|
2022-02-16 21:17:13 +00:00
|
|
|
'label' => _m('Subscribe'),
|
2021-12-10 13:52:18 +00:00
|
|
|
'attr' => [
|
2021-12-11 10:48:08 +00:00
|
|
|
'title' => _m('Add this search as a feed in your feeds section of the left panel'),
|
2021-12-10 13:52:18 +00:00
|
|
|
],
|
|
|
|
],
|
2021-12-11 10:48:08 +00:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$form_definition[] = [
|
|
|
|
$form_name = 'submit_search',
|
|
|
|
SubmitType::class,
|
|
|
|
[
|
|
|
|
'label' => _m('Search'),
|
|
|
|
'attr' => [
|
|
|
|
//'class' => 'button-container search-button-container',
|
2022-01-17 16:32:41 +00:00
|
|
|
'title' => _m('Perform search'),
|
2021-12-11 10:48:08 +00:00
|
|
|
],
|
2021-10-04 12:17:14 +01:00
|
|
|
],
|
2021-12-11 10:48:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
$form = Form::create($form_definition);
|
2021-09-27 10:39:58 +01:00
|
|
|
|
|
|
|
if ('POST' === $request->getMethod() && $request->request->has($form_name)) {
|
|
|
|
$form->handleRequest($request);
|
|
|
|
if ($form->isSubmitted() && $form->isValid()) {
|
2021-12-11 10:48:08 +00:00
|
|
|
$data = $form->getData();
|
|
|
|
$redirect = false;
|
|
|
|
if ($add_subscribe) {
|
|
|
|
/** @var SubmitButton $subscribe */
|
|
|
|
$subscribe = $form->get('subscribe_to_search');
|
|
|
|
if ($subscribe->isClicked()) {
|
2022-02-21 04:49:08 +00:00
|
|
|
if (!\is_null($data['title'])) {
|
|
|
|
Event::handle('AppendFeed', [$actor, $data['title'], 'search', ['q' => $data['search_query']]]);
|
|
|
|
} else {
|
|
|
|
throw new ClientException(_m('Empty title is not allowed.'));
|
|
|
|
}
|
2021-12-11 10:48:08 +00:00
|
|
|
$redirect = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/** @var SubmitButton $submit */
|
|
|
|
$submit = $form->get($form_name);
|
|
|
|
if ($submit->isClicked() || $redirect) {
|
|
|
|
throw new RedirectException('search', ['q' => $data['search_query']]);
|
|
|
|
}
|
2021-09-27 10:39:58 +01:00
|
|
|
}
|
|
|
|
}
|
2021-12-10 13:40:42 +00:00
|
|
|
return $form->createView();
|
|
|
|
}
|
2021-09-27 10:39:58 +01:00
|
|
|
|
2021-12-10 13:40:42 +00:00
|
|
|
/**
|
|
|
|
* Add the search form to the site header
|
|
|
|
*
|
2022-10-19 22:39:17 +01:00
|
|
|
* @param string[] $elements
|
|
|
|
*
|
2021-12-10 13:40:42 +00:00
|
|
|
* @throws RedirectException
|
|
|
|
*/
|
2022-04-03 21:40:32 +01:00
|
|
|
public function onPrependRightPanelBlock(Request $request, array &$elements): EventResult
|
2021-12-10 13:40:42 +00:00
|
|
|
{
|
2022-01-17 16:32:41 +00:00
|
|
|
$elements[] = Formatting::twigRenderFile('cards/search/view.html.twig', ['search' => self::searchForm($request)]);
|
2021-09-27 10:39:58 +01:00
|
|
|
return Event::next;
|
|
|
|
}
|
2021-10-04 12:17:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Output our dedicated stylesheet
|
|
|
|
*
|
2022-10-19 22:39:17 +01:00
|
|
|
* @param string[] $styles stylesheets path
|
2021-10-04 12:17:14 +01:00
|
|
|
*/
|
2022-04-03 21:40:32 +01:00
|
|
|
public function onEndShowStyles(array &$styles, string $route): EventResult
|
2021-10-04 12:17:14 +01:00
|
|
|
{
|
|
|
|
$styles[] = 'components/Search/assets/css/view.css';
|
|
|
|
return Event::next;
|
|
|
|
}
|
2021-09-27 10:39:58 +01:00
|
|
|
}
|