kaystrobach / visualsearch
package to handle advanced facetted searches
Installs: 10 383
Dependents: 1
Suggesters: 0
Security: 0
Stars: 5
Watchers: 4
Forks: 2
Open Issues: 4
Type:neos-package
Requires
- neos/flow: ~7.0 || ^8.0
- dev-master
- 3.5.0
- 3.4.1
- 3.4.0
- 3.3.0
- 3.2.0
- 3.1.1
- 3.1.0
- 3.0.0
- 2.x-dev
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.1
- 2.2.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.1
- 2.0.0
- 1.6.x-dev
- 1.6.5
- 1.6.4
- 1.6.3
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.0
- 1.3.0
- 1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.5.x-dev
- 0.5.1
- 0.5.0
- 0.4.1
- 0.4.0
- dev-analysis-lZvYad
This package is auto-updated.
Last update: 2025-01-10 07:59:06 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.