承接 hudhaifas-forks/silverstripe-extensible-search 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hudhaifas-forks/silverstripe-extensible-search

Composer 安装命令:

composer require hudhaifas-forks/silverstripe-extensible-search

包简介

This module allows user customisation and developer extension of a search page instance, including analytics and suggestions.

README 文档

README

The current release is 4.1.4

This module allows user customisation and developer extension of a search page instance, including analytics and suggestions.

Requirement

  • SilverStripe 3.1 → 4.0

Getting Started

Overview

Extensible Search Page

This is automatically created, and allows configuration for search based on a search engine (more below).

page

Search Engine

The extensible search page is designed to use full-text search out of the box, while providing support for custom search engine implementations (elastic search for example).

Full-Text

SilverStripe\ORM\Search\FulltextSearchable:
  searchable_classes:
    - 'SilverStripe\CMS\Model\SiteTree'
SilverStripe\CMS\Model\SiteTree:
  create_table_options:
    MySQLDatabase: 'ENGINE=MyISAM'
  extensions:
    - "SilverStripe\\ORM\\Search\\FulltextSearchable('Title', 'MenuTitle', 'Content', 'MetaDescription')"

When considering the search engine to use, full-text has some important limitations. This configuration can also be applied to File, however, unfortunately it does not support further customisation.

Custom Search Engine

The following is an example configuration, where ElasticSearch extends the abstract CustomSearchEngine class:

nglasl\extensible\ExtensibleSearchPage:
  custom_search_engines:
    nglasl\extensible\ElasticSearch: 'Elastic'

Search Form

PageController:
  extensions:
    - 'nglasl\extensible\ExtensibleSearchExtension'

Using this, to display the search form that users interact with (from your template):

$SearchForm

Search Analytics

These are important to help determine either popular content on your site, or whether content is difficult for users to locate. They're automatically enabled out of the box, however, can be disabled using the following:

nglasl\extensible\ExtensibleSearch:
  enable_analytics: false

analytics

When triggering a search, appending ?analytics=false to the URL will bypass the search analytics. This is fantastic for debugging.

Archiving

Depending on your search traffic, /dev/tasks/ExtensibleSearchArchiveTask may be used to archive past search analytics, for each search page. It would be recommended to trigger this on a schedule where possible.

archives

archive

Search Suggestions

These are most effective alongside the search analytics (in which case they're automatically populated), and can be used to display either popular searches on your site, or search form autocomplete options. They're automatically enabled out of the box, however, can be disabled using the following:

nglasl\extensible\ExtensibleSearchSuggestion:
  enable_suggestions: false

suggestions

To enable autocomplete using the approved search suggestions..

Requirements::javascript('nglasl/silverstripe-extensible-search: client/javascript/extensible-search-suggestions.js');

// OPTIONAL.

Requirements::css('jquery-ui.min.css');
Requirements::javascript('jquery-ui.min.js');

Smart Templating

Custom search engine specific templates may be defined for your search results. These are just two examples:

ElasticSearch_results.ss or Page_results.ss

SS4 Changes

  • The custom search engine implementation has changed, and no longer uses extensions (see above).

Maintainer Contact

Nathan Glasl, nathan@symbiote.com.au

统计信息

  • 总下载量: 73
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 15
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2024-02-23