| 
									
										
										
										
											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; | 
					
						
							| 
									
										
										
										
											2021-12-11 10:48:08 +00:00
										 |  |  | use App\Util\Common; | 
					
						
							| 
									
										
										
										
											2021-09-27 10:39:58 +01:00
										 |  |  | use App\Util\Exception\RedirectException; | 
					
						
							|  |  |  | 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 | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     public function onAddRoute($r) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $r->connect('search', '/search', Controller\Search::class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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[] = [ | 
					
						
							| 
									
										
										
										
											2021-12-11 22:20:25 +00:00
										 |  |  |                 'title', TextType::class, ['label' => _m('Title'), 'required' => false, 'attr' => ['title' => _m('Title for this new feed in your left panel')]], | 
					
						
							| 
									
										
										
										
											2021-12-11 10:48:08 +00:00
										 |  |  |             ]; | 
					
						
							|  |  |  |             $form_definition[] = [ | 
					
						
							|  |  |  |                 'subscribe_to_search', | 
					
						
							|  |  |  |                 SubmitType::class, | 
					
						
							| 
									
										
										
										
											2021-12-10 13:52:18 +00:00
										 |  |  |                 [ | 
					
						
							| 
									
										
										
										
											2021-12-11 10:48:08 +00:00
										 |  |  |                     'label' => _m('Subscribe to this search'), | 
					
						
							| 
									
										
										
										
											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',
 | 
					
						
							|  |  |  |                     'title' => _m('Query notes for specific tags.'), | 
					
						
							|  |  |  |                 ], | 
					
						
							| 
									
										
										
										
											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()) { | 
					
						
							| 
									
										
										
										
											2021-12-11 22:20:25 +00:00
										 |  |  |                         // TODO ensure title is set
 | 
					
						
							| 
									
										
										
										
											2021-12-11 10:48:08 +00:00
										 |  |  |                         Event::handle('AppendFeed', [$actor, $data['title'], 'search', ['q' => $data['search_query']]]); | 
					
						
							|  |  |  |                         $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 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @throws RedirectException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function onAddExtraHeaderForms(Request $request, array &$elements) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $elements[] = 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 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $styles stylesheets path | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-10-10 09:26:18 +01:00
										 |  |  |      * @return bool hook value; true means continue processing, false means stop | 
					
						
							| 
									
										
										
										
											2021-10-04 12:17:14 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-10-06 00:34:27 +01:00
										 |  |  |     public function onEndShowStyles(array &$styles, string $route): bool | 
					
						
							| 
									
										
										
										
											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
										 |  |  | } |