npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@cloak-app/algolia

v0.4.0

Published

Record syncing generate hook and SSR components for Algolia with Nuxt.

Downloads

19

Readme

@cloak-app/algolia

Record syncing generate hook and SSR components for Algolia with Nuxt.

Install

  1. Install with yarn add @cloak-app/algolia
  2. Add to nuxt.config with buildModules: ['@cloak-app/algolia']

Module Options

Set these properties within cloak: { algolia: { ... } } in the nuxt.config.js:

Credentials

  • appId - Algolia app ID, defaults to process.env.ALGOLIA_APP_ID.
  • searchKey - Algolia public search API key, defaults to process.env.ALGOLIA_SEARCH_KEY.
  • adminKey - Algolia private admin API key, defaults to process.env.ALGOLIA_ADMIN_KEY.

Syncing

  • syncHook - The Nuxt lifecycle to run sync operation on. Defaults to generate:before, a good default if you are using Algolia data during SSR. If you only use client side, change to generate:done to prevent syncing if the generate operation fails.
  • sync - An array of sync configuration rules. There shoud be an array item for each index you want to sync to. See Usage for more information.

Project Dependencies

  • .max-w* styles (included in Cloak via whitespace.styl)

Usage

Sync

In the sync array's simplest form, give it a simple string per index:

// nuxt.config.js
export default {
  cloak: {
    algolia: {
      sync: ['articles'],
    }
  }
}

This does a couple a couple of things:

  • It will create an Algolia index automatically during yarn generate that named ${env}_${site}_${name} where env is derived from $config.cloak.boilerplate.appEnv and site is derived from $config.cloak.craft.site. For example, prod_en-US_articles.

  • It will query the CMS for records matching that name. If using Craft, this means querying for all entries that have a section of articles. The composition of these entry objects is made using a gql fragment that is expected to live at ~/queries/fragments/article.gql. This should be the same fragment that is used to render these entries in other places on the site where they are listed. Thus, if you render these entries in some sort of card UX, the objects returned by Algolia and the objects returned by the CMS should be identical so you can directly render the card components without any massaging of Algolia data.

The sync array also supports an expanded form, if you want to tweak any of these names.

// nuxt.config.js
export default {
  cloak: {
    algolia: {
      sync: [
        {
          name: 'blogs',
          indexName: 'prod_articles',

          // Use Craft helpers ...
          fragmentPath: 'path/to/fragment.gql',
          fragmentNames: ['blog', 'pressRelease'], // Optional
          section: 'blog', // Craft section type
          type: 'article', // Craft entry type, optional

          // ... or completely replace the query and variables ...
          // query: `query($section:[String]) {...}`,
          // variables: { section: "blog", category: "..." },

          // ... or fetch all your records some other way ...
          // records: [{ ... }],

          // Set Algolia index settings
          // https://www.algolia.com/doc/api-reference/settings-api-parameters/
          settings: {},

          // Set Algolia rules
          // https://www.algolia.com/doc/api-client/methods/rules/
          rules: [],

          // Set Algolia synonyms
          // https://www.algolia.com/doc/api-client/methods/synonyms/
          synonyms: [],
        }
      ],
    }
  }
}

Another common pattern is merging Shopify product data with CMS product data. This can be easily accomplished with the mergeShopify option:

// nuxt.config.js
export default {
  cloak: {
    algolia: {
      sync: [{
        name: 'products,
        mergeShopify: 'products',
      }],
    }
  }
}

This uses the @cloak-app/shopify package to fetch products that match the CMS products, comparing CMS slugs with Shopify handles. The product fragment is used with the Shopify data.

CLI

You can manually run the sync operation by running the following from within your Nuxt directory:

$ yarn algolia-sync

Contributing

Run yarn dev to open a Nuxt dev build of the demo directory.

To work on the record-sync module, run chmod +x ./cli.js to make cli.js executable and then run ./cli.js demo --mock to run the record-sync process using the demo Nuxt environment.