Alchemy CMS Postgresql Fulltext Search
This gem provides full text search for projects using postgresql databases to Alchemy CMS 7.0 and above.
Requirements
- Ruby 3.0 or newer
- Alchemy CMS 7.0 or newer
- PostgreSQL 12.x or newer
Installation
Add this line to your application's Gemfile
:
gem 'alchemy-pg_search', github: 'AlchemyCMS/alchemy-pg_search', branch: 'main'
And then execute:
$ bundle install
Run install script:
$ bin/rails g alchemy:pg_search:install
[!NOTE]
The installation will generate an autogenerated column which can be configured with a language. The default value should work for the most languages. If you wish to change this behavior you should add theAlchemy::PgSearch.config
into the project initializer before running the install script. (See Configure Behavior)
Usage
Every Ingredient
will be indexed unless you tell Alchemy to not index a specific content.
Disable Indexing
Exclude whole pages from the search index
Pass searchable: false
to your page layout definitions and Alchemy will not index that particular page.
# page_layouts.yml
- name: secret_page
searchable: false
elements:
- secret_sauce
Exclude whole elements from the search index
Pass searchable: false
to your element definitions and Alchemy will not index that particular element.
# elements.yml
- name: secret_sauce
searchable: false
ingredients:
- role: sauce
type: Text
default: 'This is my secret sauce.'
Exclude single contents from being indexed
Pass searchable: false
to your content definitions and Alchemy will not index that particular content.
# elements.yml
- name: secrets
ingredients:
- role: passwords
type: Text
searchable: false
default: 'This is my secret password.'
The same works for ingredients
as well
# elements.yml
- name: secrets
ingredients:
- role: passwords
type: Text
searchable: false
default: 'This is my secret password.'
Configure Behavior
Configure the gem in an initializer. The default configurations are:
Rails.application.config.before_initialize do
Alchemy::PgSearch.config = {
dictionary: 'simple',
paginate_per: 10
}
end
[!NOTE]
Be aware thatbefore_initialize
is used. Otherwise the configuration will not have an effect, because of the load order in Rails.
Configuration Name | Default Value | Description |
---|---|---|
dictionary | simple | Dictionary for the multisearch tsearch - config, which is used to find the content. The dictionary can impact the amout found documents, because it removes language specific stop words. See more in the PostgreSQL documentation. |
paginate_per | 10 | Amount of results per page. The value can be set to nil to disable the pagination. |
You can also overwrite the default multisearch configuration to use other search strategies. For more information take a look into the PgSearch Readme.
Rails.application.config.after_initialize do
::PgSearch. = {
using: {
tsearch: { prefix: true }
}
}
end
Rendering search results.
In order to render the search results, you'll need a page layout that represents the search result page. Simply mark a
page layout as searchresults: true
. The search form will pick this page as result page.
Search Results Page
Add a search layout to the page_layout.yml
and mark it with a searchresults
flag. These flag is used to find the
correct page path for search form.
# page_layouts.yml
- name: search
searchresults: true
unique: true
elements:
- searchresults
autogenerate:
- searchresults
# elements.yml
- name: searchresults
unique: true
and then use the view helpers to render the search form on the page layout partial.
<!-- app/views/alchemy/page_layouts/_search.html.erb -->
<%= render_elements %>
<!-- app/views/alchemy/elements/_searchresults.html.erb -->
<%= element_view_for(searchresults) do |el| -%>
<% search_results = Alchemy::Search::SearchPage.perform_search(params, ability: current_ability) %>
<%= render "alchemy/search/results", search_results: search_results %>
<% end %>
View Helpers
This gem provides some helper methods that let you render the form and the search results.
- Render the search form:
render_search_form
Customize Views
If you want to override the search form and search result views please use this generator.
$ bin/rails g alchemy:pg_search:views
Translating Views
The views are fully translatable. German and english translations are already provided with this gem.
If you want add your own translation, just place a locale file into your projects config/locales
folder.
Here is the english example:
en:
alchemy:
search_form:
placeholder: 'Search query'
submit: 'Search'
search_result_page:
result_page: Page
no_results: "Your search for '%{query}' offers no result"
result_heading: "Your search for '%{query}'"
result_count:
one: 'Offers one result'
other: 'Offers %{count} results'
Upgrading
If you are upgrading from v3.0.0 please run the install generator:
$ bin/rails g alchemy:pg_search:install
$ bin/rake db:migrate
and reindex your database in your Rails console
# rails console
$ Alchemy::PgSearch.rebuild
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request