Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@graphcommerce/algolia-search

Package Overview
Dependencies
Maintainers
2
Versions
379
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@graphcommerce/algolia-search

Implementation of Algolia Instant Search inside Graphcommerce. Add client or server side product, category and pages search to your project!

  • 6.2.0-canary.63
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
339
decreased by-20.42%
Maintainers
2
Weekly downloads
 
Created
Source

Implementation of Algolia Instant Search inside Graphcommerce. Add client or server side product, category and pages search to your project!

Installation

  1. Find current version of your @graphcommerce/next-ui in your package.json.
  2. yarn add @graphcommerce/algolia-search@1.2.3 (replace 1.2.3 with the version of the step above)

Add config values to Graphcommerce configuration

This plugin contains different app and storefront configuration values.

App configuration values:

  • algoliaApplicationId
  • algoliaSearchOnlyApiKey
  • algoliaSearchDebounceTime,

Storefront configuration values:

  • algoliaSearchIndexConfig (containing a list of the following values)
    • searchIndex
    • filterAttributes (containing a list of the following values)
      • aggregation
      • toAlgoliaAttribute
  1. Add react-instantsearch-hooks-server package to your project
yarn add react-instantsearch-hooks-server

or

npm install react-instantsearch-hooks-server
  1. Add the new serverState property to the SearchResultProps type
type SearchResultProps = DefaultPageQuery &
  ProductListQuery &
  ProductFiltersQuery &
  CategorySearchQuery & {
   filterTypes: FilterTypes
   params: ProductListParams
+   serverState?: unknown
   }
  1. Add the getServerState method from the react-instantsearch-hooks-server package to the imports of your search page
...
import { getServerState } from 'react-instantsearch-hooks-server'
...
  1. Assign the result of the getServerState method to the serverState attribute inside of the return statement.
return {
    props: {
      ...(await page).data,
      ...(await products).data,
      ...(await filters).data,
      ...(await categories)?.data,
      ...(await layout)?.data,
      filterTypes: await filterTypes,
      params: productListParams,
      up: { href: '/', title: 'Home' },
      apolloState: await conf.then(() => client.cache.extract()),
+     serverState: await getServerState(<SearchContext rendersInsideNextjs={false} />, {
+      renderToString,
+     }),
    },
    revalidate: 60 * 20,
  }
  1. Add the serverState to the SearchContext component.
+ const { products, categories, params, filters, filterTypes, serverState } = props
  const search = params.url.split('/')[1]
  const totalSearchResults = (categories?.items?.length ?? 0) + (products?.total_count ?? 0)
  const noSearchResults = search && (!products || (products.items && products?.items?.length <= 0))

  return (
    <>
      <PageMeta
        title={
          search
            ? i18n._(/* i18n */ 'Results for ‘{search}’', { search })
            : i18n._(/* i18n */ 'Search')
        }
        metaRobots={['noindex']}
        canonical='/search'
      />

+     <SearchContext serverProps={serverState}>

FAQs

Package last updated on 14 Jul 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc