kaystrobach / visualsearch
package to handle advanced facetted searches
Installs: 10 381
Dependents: 1
Suggesters: 0
Security: 0
Stars: 5
Watchers: 4
Forks: 2
Open Issues: 3
Type:neos-package
Requires
- neos/flow: ~7.0 || ^8.0
This package is auto-updated.
Last update: 2024-12-13 17:01:01 UTC
README
This package provides a powerful search component for Flow ecosystem. Any search repository can be made searchable by
extending SearchableRepository
and providing an appropriate configuration. The front-end component is provided as a
Fluid partial.
Installation
composer require kaystrobach/visualsearch:^3.0.0
Usage
To make a repository searchable, extend SearchableRepository
or implement the SearchableRepositoryInterface
.
Note that the defaultSearchName
property should set to the name of the corresponding search configuration.
<?php namespace Poke\Search\Domain\Repository; use Neos\Flow\Annotations as Flow; use Neos\Flow\Persistence\Repository; use KayStrobach\VisualSearch\Domain\Repository\SearchableRepository; /** * @Flow\Scope("singleton") */ class PokemonRepository extends SearchableRepository { /** * @var string */ protected $defaultSearchName = 'pokemon'; public function findByName(string $name) { ... } }
The repository can now be queried using the findByDefaultQuery
method, e.g., from inside a controller action.
public function indexAction() { $this->view->assign('pokemon', $this->pokemonRepository->findByDefaultQuery()); }
To actually display the search component, include the search partial in your template.
<f:render partial="Visualsearch/Search" arguments="{searchName:'pokemon', pokemon:pokemon}" contentAs="value"> ... </f:render>
Configuration
Search configurations are defined in the Configuration/VisualSearch.yaml
file. Please see the demo package for an
example configuration.
Theming
The search component can be styled using the following CSS properties:
Development
Install front-end dependencies via npm.
cd Resources/Private/App
npm install
After making changes to the front-end code, run the build script to bundle the assets.
npm run build
Linters are available for both JavaScript and CSS templates.
npm run lint:js npm run lint:css
License
This project is licensed under the MIT License.