fahlgrendigital / packages-statamic-algolia-support
Support for the Algolia driver in Statamic applications.
Installs: 161
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 0
Open Issues: 0
pkg:composer/fahlgrendigital/packages-statamic-algolia-support
Requires
- php: ^8.3
- algolia/algoliasearch-client-php: ^3.4
- illuminate/support: ^11.0
- league/csv: ^9.21.0
- statamic/cms: ^5.0
Requires (Dev)
- orchestra/testbench: ^9.0
- phpunit/phpunit: ^11.0
README
Add helpful support classes for working with the Algolia driver in Statamic applications.
Installation
$ composer require fahlgrendigital/packages-statamic-algolia-support
Publish
$ php artisan vendor:publish --tag=statamic-algolia-support-config
Usage
This package focuses on a few different areas of support for the Algolia driver in Statamic applications:
- Transformers
- Index building
- Index importing
Transformers
This package offers three transformers designed for handling complex data types in Statamic.
- CollectionTransformer
- DateTransformer
- MarkupTransformer
CollectionTransformer
This transformer currently transformers a collection object into the handle. A common use case for this field is configuring it as a facet in your Algolia index for filtering.
DateTransformer
This transformer currently transformers a date object into a formatted date string using the following format: Y-m-d H:i:s.
MarkupTransformer
This transformer supports the following field types within Statamic:
- Bard
- Textarea
Indexes
This package offers a simple index builder for creating Algolia indexes in your Statamic application. You can configure a laravel filesystem disk to store your indexes in. This is useful for keeping your indexes in sync across multiple algolia environments. Statamic will automagically handle saving CRUD operations for configured index sources in Algolia, and the index builder is designed to handle cases where you want to do an entire index update within Algolia.
Commands
$ php artisan algolia:search-index:build-file {index} -T json/csv -D --json-stats
- {index}- The index to build.
- -T- The type of file to build. Options are- jsonor- csv.
- -D- Whether to do a dry run.
- --json-stats- Whether to output the stats in for a JSON index export (max, min, avg size).
$ php artisan algolia:build-computed-indexes
This command loops through the configured compound indexes in your config/statamic-algolia-support.php file and builds them.
Example
'computed_indexes' => [ 'my_index' => ['first_index', 'second_index'], ]