Building a simple price comparison server with nextjs

Siso Ngqolosi

Published on Tuesday, Mar 12, 2024

Hey there, tech enthusiasts! Get ready for a wild ride as we dive into the world of string matching and price comparison with a dash of Node.js magic! 🚀

In this tutorial, we'll be building a simple Express server that can compare product names across multiple stores and return the matching products along with their prices. Buckle up, folks, because we're about to have some serious fun! 🤓

First things first, let's set up our project. We'll need to install the necessary dependencies:

npm install express string-similarity

Now that we've got our dependencies sorted, it's time to start coding! Create a new file called app.js and let's get cracking.

const express = require("express");
const app = express();
const stringSimilarity = require("string-similarity");

We're importing the express module to create our server and the string-similarity library to help us compare product names. Because, let's be real, people can be pretty creative when it comes to naming products!

Next, we'll define our sample product data from three different stores:

// Sample product data
const store1Products = [
  { name: "Whole Milk", price: 2.99 },
  { name: "Organic Apples", price: 3.49 },
  { name: "Cheddar Cheese", price: 4.99 },
];

const store2Products = [
  { name: "Dairy Pure Milk", price: 2.79 },
  { name: "Organic Apples", price: 3.29 },
  { name: "Sharp Cheddar", price: 5.49 },
];

const store3Products = [
  { name: "Milk Whole", price: 2.59 },
  { name: "Apples Organic", price: 3.99 },
  { name: "Cheddar Cheese Block", price: 4.79 },
];

Now, we need to define some helper functions to normalize and compare strings:

function normalizeString(str) {
  return str.toLowerCase().replace(/\W/g, "");
}

function compareTwoStrings(str1, str2) {
  const normalized1 = normalizeString(str1);
  const normalized2 = normalizeString(str2);
  return stringSimilarity.compareTwoStrings(normalized1, normalized2);
}

The normalizeString function converts the input string to lowercase and removes all non-word characters (like punctuation and whitespace). The compareTwoStrings function uses the normalizeString function to preprocess the input strings and then compares them using the stringSimilarity.compareTwoStrings method.

Now, for the main event! We'll set up an Express route to handle our price comparison requests:

app.get("/compare-prices", (req, res) => {
  const query = req.query.query || "";
  const threshold = 0.4; // Adjust this threshold as needed
  const allProducts = [...store1Products, ...store2Products, ...store3Products];
  console.log(allProducts.length);
  const matchingProducts = allProducts.filter((product) =>
    compareTwoStrings(product.name, query) > threshold
  );
  res.json(matchingProducts);
});

When a GET request is made to /compare-prices, we first retrieve the search query from the query string (req.query.query). We also set a similarity threshold (in this case, 0.4) to determine how similar the product names need to be to be considered a match.

Next, we combine the product data from all three stores into a single array (allProducts). We then use the filter method to find all products whose names are similar enough to the search query (based on the compareTwoStrings function and the specified threshold).

Finally, we send the matching products as a JSON response (res.json(matchingProducts)).

To start our server, we'll add the following lines:

const port = process.env.PORT || 3000;
app.listen(port, () => console.log(`Server running on port ${port}`));

And that's it, folks! Our price comparison server is up and running! 🎉

To test it out, you can start the server with node app.js and then make a GET request to http://localhost:3000/compare-prices?query=milk. You should see an array of matching products from all three stores.

Of course, this is just a simple example, but you can expand on it and add more features like authentication, database integration, and even a fancy user interface. The possibilities are endless!

Happy coding, my fellow tech wizards! And remember, always have fun and don't be afraid to experiment. Who knows, you might just create the next big thing in price comparison technology! 🎩

Clone the repo:

git clone https://github.com/your-username/price-comparison-server.git