/medusa-products-bought-together

Medusa plugin which monitors and provides API for getting products which are frequently bought together.

Primary LanguageTypeScriptMIT LicenseMIT

Medusa store-analytics logo

Medusa Products Bought Together

Note: This plugin will be migrated to Medusa v2, when v2 will reach production readiness.

Medusa "Products Bought Together" is a plugin which monitors and provides API for getting products which are frequently bought together.

Why?

When customer wants to buy product A, he can get information about other products which are frequently bought together with product A.

It is a common scenario for ecommerce, which leds to increasing sales by recommending such products to customers.

Getting Started

  1. Install the package with yarn add @rsc-labs/medusa-products-bought-together or npm i @rsc-labs/medusa-products-bought-together.
  2. In medusa-config.js, add the plugin to the plugins array.
const plugins = [
  // ... other plugins
  {
    resolve: `@rsc-labs/medusa-products-bought-together`,
    options: {
      
    }
  }
]
  1. Run migrations, e.g. npx medusa migrations run (see: https://docs.medusajs.com/development/entities/migrations/overview) as plugin uses new tables.

How it works?

When customer places new order, plugin takes information about all products in order and creates entries in database. If there is already existing pair of products (because they were bought together before), then it increases its ranking. In a result, there is a stored information about relations between products and how frequently they are bought together.

How can I use it?

When you install a plugin, monitoring is being done automatically.

To use it, you can use API described below:

openapi: 3.0.0
info:
  title:  API
  description: API for plugin
  version: 0.0.1
paths:
  /store/boughtTogether/{productId}:
    get:
      summary: List of products
      description: Returns a list of products which are bought together with {productId}
      parameters:
        - name: productId
          in: path
          description: ID of product for which you are looking for other products
          required: true
          schema:
            type: string
      responses:
        '200':
          description: productId passed in URL. Returns empty array if cannot be found in database.
          content:
            application/json:
              schema: 
                type: array
                items:
                  type: object
                  properties:
                    productId:
                      type: string
                    boughtTogetherProductId:
                      type: string
                    frequency:
                      type: number
        '404':
          description: productId not passed in URL

For example:

Request: https://localhost:9000/store/boughtTogether/prod_1123123123

Response:

[
    {
        "productId": "prod_1123123123",
        "boughtTogetherProductId": "prod_2223432432423",
        "frequency": 10
    },
    {
        "productId": "prod_1123123123",
        "boughtTogetherProductId": "prod_334343434343",
        "frequency": 4
    }
]

Configuration

There is a limit set for GET requests equal to: 5

You can change this limit by providing getLimit option to plugin:

const plugins = [
  // ... other plugins
  {
    resolve: ``,
    options: {
        getLimit: 10
    }
  }
]

TODO

[ ] Tests

[ ] Make limit per request, as we can't use "query" params in API routes (req.body in GET REST API sounds weak).

Contribution

Contributions are welcome and they are greatly appreciated!

License

MIT


© 2023 RSC https://rsoftcon.com/